Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17


Lucene: "FileNotFoundException"

Posted on 2004-04-30
Medium Priority
Last Modified: 2012-08-13
I'm using threads in which i'm searching an xml index and sometimes updating the index also.....

However, (probabaly on the occasions when the two threads(+) conincide) i get a "FileNotFoundException": the system cannot find the path specified...
or else an "IOException": couldn't delete _4.fl

So, i'm presuming that there is a conflict, whenever there may be an indexing and a search at the same time?

(By the way.....
I'm using Digester to parse & index the xml file
In my xmlParser class, i have a 'contacts' class (which holds all the properties or each contact entry which must be declared public and static for digester to instantiate it....)

How could i make sure these two errors never occur.......
Question by:vinoboy
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 3
LVL 30

Expert Comment

by:Mayank S
ID: 10958628
>> couldn't delete _4.fl

Do you also try to delete the files somewhere?

Author Comment

ID: 10958743
No, i didn't, but i presume that when its updating the index (ie, overwriting i think) that it deletes them itself
LVL 30

Expert Comment

by:Mayank S
ID: 10958771
Make sure that you synchronize your file-access properly. Ideally, when a file is being read by a thread, no other thread should write to it till that one closes it. Sameway, if a file is being written into by one thread, you should not let any other thread read from it till this one closes it.
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!


Author Comment

ID: 10958800
And an easily implementable and reliable way to do the synchronisation of file access is?
LVL 30

Expert Comment

by:Mayank S
ID: 10958839
Perhaps you could use a common log-file. If a file is being written to, then the program would write its name to this file. Any other threads trying to access that file would wait till the file's entry is removed from that log-file (which will be done by the thread using it, after it is done with the file).

You could also carefully use synchronization between threads, but I don't have your code to help you with that.

Author Comment

ID: 10958887
I'll give the log file a shot....Its mere existance could tell me that the 'updating index' program is been used...
LVL 30

Expert Comment

by:Mayank S
ID: 10958918
Don't check only for existance. Let the log-file always be there. Let the existance of the working file-name in the log-file decide whether it is to be accessed or not. You can write a separate class for this log-file purpose.

Expert Comment

ID: 10959066
use locks to lock the file before you access it so that no other thread/process can change it

import java.nio.channels.*; //works on 1.4 only

FileLock lck = new FileOutputStream("C:\\File").getChannel().tryLock();
            if(lck == null)
      System.out.println("Another thread is already accesing the file....");

c:\\file can be the common file which is locked.if this file is not locked then a thread can do the required if it is locked then the thread has to wait.

LVL 30

Accepted Solution

Mayank S earned 200 total points
ID: 10959155
Ah, indeed~! Should've thought of that! Have been working on 1.3 a lot these days! You can see more on locks here:

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Java contains several comparison operators (e.g., <, <=, >, >=, ==, !=) that allow you to compare primitive values. However, these operators cannot be used to compare the contents of objects. Interface Comparable is used to allow objects of a cl…
Introduction Java can be integrated with native programs using an interface called JNI(Java Native Interface). Native programs are programs which can directly run on the processor. JNI is simply a naming and calling convention so that the JVM (Java…
Viewers will learn about if statements in Java and their use The if statement: The condition required to create an if statement: Variations of if statements: An example using if statements:
The viewer will learn how to implement Singleton Design Pattern in Java.
Suggested Courses

704 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question