Listener being called twice
2 views (last 30 days)
Show older comments
I created a listener to monitor changes to a file. When I make a change to that file the function that is called from the listener runs twice when it should run once. Here is the code for the listener. The function eventhandlerChanged just displays the word 'changed'.
fileObj = System.IO.FileSystemWatcher('c:\Temp')
fileObj.Filter = 'test.txt'
fileObj.EnableRaisingEvents = true
lh=addlistener(fileObj,'Changed',@eventhandlerChanged)
0 Comments
Answers (2)
per isakson
on 18 Feb 2015
The FileSystemWatcher documentation says that a simple file operation can
raise multiple events.
To turn off the event handler, type: fileObj.EnableRaisingEvents = false;
3 Comments
per isakson
on 18 Feb 2015
I don't know! However, these words in the documentation indicate that what you see is expected under some circumstances. Furthermore, the documentation refers to FileSystemWatcher Class or similar.
per isakson
on 19 Feb 2015
Edited: per isakson
on 19 Feb 2015
Did you read the documentation on
>> fileObj.NotifyFilter
ans =
FileName, DirectoryName, LastWrite
Guillaume
on 19 Feb 2015
As per isakson says, this is a possible behaviour of the FileSystemWatcher. There's nothing you can do to stop the event being raised multiple time on a file modification.
Therefore, what you must do is make your event handler more resilient to this possibility. A fairly simple way would be to store the filename and timestamp of the call to your handler. If the filename is the same and the time elapsed between two calls is too short, simply not process again.
Another option is to implement some sort of queue of files to process, delayed by a few seconds. If in the queue the same file is present several times in a row, just collapse them all into one event.
0 Comments
See Also
Categories
Find more on Scope Variables and Generate Names in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!