|
Interesting. When I run it on an empty directory, I get a zero-length array.
Also, it doesn't make any difference if I put "C:\\someFolder" or "C:\\someFolder\\". It behaves the same in both cases.
I only get null back if there is some kind of problem (e.g. Access denied).
|
|
|
|
|
I'll try it again sometime and check the results more closely.
The best things in life are not things.
|
|
|
|
|
Come on guys. My question is how can I find a file in "C", not in "C:\someFolder"? ... on the latter case it works easily. If you have time try to run my code, it really works. But try to make the searching folder "C:\" not "C:\someFolder". Then it will through an exception. Though thank you for your help
|
|
|
|
|
Consider these lines:
File[] list=file1.listFiles();
for(File x: list)
if file1.listfiles() does not return any items then list will be null and the runtime will throw an exception. Took me less than 5 minutes to find it with the debugger.
Lesson: Check return values and statuses, and catch exceptions: there is no alternative.
The best things in life are not things.
|
|
|
|
|
Hi,
some comments:
1.
you should implement error handling in your code; have a try-catch and log the exception.
2.
when an exception occurs, it gives the number of the offending line; that is where the problem shows itself, the actual cause may be somewhat sooner.
3.
when the exception occurs in a method call, check the documentation for that method to see what it has to say about the specific exception. That should tell you exactly what is wrong.
4.
Your searchForFile() method is a bit silly, it tells whether a file exists, but when it does, it does not tell you where it is. A better definition of it would return the path to the first occurence it finds as a string.
Luc Pattyn [Forum Guidelines] [My Articles] Nil Volentibus Arduum
Please use <PRE> tags for code snippets, they preserve indentation, improve readability, and make me actually look at the code.
|
|
|
|
|
What is the result of running the following? If it is exception then post the entire stack trace.
File file1=new File("C:\\");
System.out.println("exists=" + file1.exists());
|
|
|
|
|
This works for me.
As someone else has pointed out, file1.listFiles() may return null so you need to allow for that.
|
|
|
|
|
I am reduced to "someone else".
The best things in life are not things.
|
|
|
|
|
Hi all,
I am having one small doubt. If string is a immutable class then how come it is allow us change ? ex: String s1="abc"; s1="def"; Sop(s1); it gives op as :- def. does it mean we have made changes on string object ? please tell me.
Thanks
************ S G KORE *******************
|
|
|
|
|
"abc" and "def" are strings.
s1 is not a string, it is a variable holding a reference to a string. at first it refers to "abc", later on it refers to "def".
The string "abc" never got modified, it may still be alive (kept alive by another reference, as in the example below), or it is dead and garbage collectible.
string s1="abc";
string s2=s1;
s1="def";
Sop(s1);
Sop(s2);
Luc Pattyn [Forum Guidelines] [My Articles] Nil Volentibus Arduum
Please use <PRE> tags for code snippets, they preserve indentation, improve readability, and make me actually look at the code.
|
|
|
|
|
Thank you Luc Pattyn. Now I got clear picture .
************ S G KORE *******************
|
|
|
|
|
In addition to the above comment, what I suggest you is that try to draw a picture in a paper while you work on Object types & references so that you will always know what you are doing and have the right picture in your mind. It is very helpful, even in Arrays and Memory Allocations
|
|
|
|
|
I want to develope a desktop application in java which has TCP client on desktop.It connect to the server.And whenever TCP server sends message to this client,an alert(like balloon tip in windows) should appeared on my desktop where my application is running.This alert is timed alert.It should disappear after 3 seconds.
I am new to java so any help will be appreciated.
|
|
|
|
|
1. Learn basics of java
2. Learn GUI programming
3. Learn threads, including but not limited to timers.
4. Learn sockets programming
5. Create server
6. Create client.
|
|
|
|
|
Good answer.
The best things in life are not things.
|
|
|
|
|
yes, a fine, and precise answer.
But I'd like to give him a hint too: How to Make Dialogs @ oracle.com[^]. Combine this with the threads[^] that jschell talked about and you'll have your "Desktop notification".
...because we all started somehow & somewhere too.
regards
Torsten
I never finish anyth...
|
|
|
|
|
Hello guys,
I have to write an in-place version of Merge-Sort which works on doubly linked lists for university.
This wouldn't be the problem, but there are a few conditions to meet.
- the algo must work in-place (additional memory usage in O(log n))
- I cannot create new list elements or entire lists, just copies (ListElement left = new List Element() isn't possible but ListElement left = first is possible)
- the algo should be recursive, but this is not necessary
- each call of the algo must return a head pointer to the first element of the sub-list
- the merge part must also return a head pointer
public DoublyLinkedList mergesort(DoublyLinkedList in, int numOfElements) {
if (numOfElements > 1) {
DoublyLinkedList firstLeft = in;
DoublyLinkedList firstRight = in;
for ( int i = 0; i < numOfElements / 2; i++ ) {
firstRight.first = firstRight.first.next;
}
DoublyLinkedList left = mergesort ( firstLeft, (int)Math.floor(numOfElements / 2 ) );
DoublyLinkedList right = mergesort ( firstRight, (int)Math.ceil(numOfElements / 2 ) );
return merge ( left, right );
} else {
return in;
}
}
My problem is that I'm somehow stuck right at the beginning. The algo itself shouldn't be the problem, but the additional conditions make the whole thing quite difficult for me.
Of course I've already searched for useful algos or something, but I didn't find anything.
Thanks in advance for your help and best wishes,
Manfred
|
|
|
|
|
Coincidentally, I have to do the exact same thing. I believe recursion might be the most efficient, good thing you've already started it that way. The code you have looks simple/efficient. HOWEVER, it looks like you followed the algorithm given to you in the "Skriptum".
Through some searching without using the keyword "pseudocode", I came across this very descriptive page which I have yet to take the time to fully comprehend (http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html)
|
|
|
|
|
In the meantime I wrote a fully working recursive implementation. However, I'm now working on an iterative version, because I'm not that fan of recursion for performance reasons.
|
|
|
|
|
I hope your iterative version has a less than linear auxiliary space requirement.
|
|
|
|
|
It has, but if I execute the program, I get an MAC error message "Segmentation fault".
I got this one time with the recursive version, but the next run finished without any errors?
Does anyone know what can cause this error, a simple Java program shouldn't do this.
|
|
|
|
|
This is really an interesting Assingment. Ive worked with MergeSort but I didnt have the Idea before that it could be effectivly implemented with DoublyLinked Lists. I would give this a try. I hope you guys will help me also
P.S. I want to implement this in C++ with Stack. I think Stack here can do a lot of work
do you have any pseudocode, so I start it easily.
|
|
|
|
|
I'm gonna write you down a few lines the next days, but at the moment I'm quite busy.
|
|
|
|
|
Indeed, a doubly linked list can make this easy, but I can already imagine it working with a singly linked list. Any idea if having a cyclical list would be of any advantage over an acyclical one?
|
|
|
|
|
In my opinion it's not an advantage for the algorithm. It can be an advantage when dealing with the data structure itself. However, if you split the list, you have to reconnect the first to the last element of the sub-list and vice versa. It's also not that easy to check whether you reached the last element, cause you need help pointers or something similar.
|
|
|
|