public interface Watchable
 This interface defines the register method to register
 the object with a WatchService returning a WatchKey to
 represent the registration. An object may be registered with more than one
 watch service. Registration with a watch service is cancelled by invoking the
 key's cancel method.
| Modifier and Type | Method and Description | 
|---|---|
| WatchKey | register(WatchService watcher,
        WatchEvent.Kind<?>... events)Registers an object with a watch service. | 
| WatchKey | register(WatchService watcher,
        WatchEvent.Kind<?>[] events,
        WatchEvent.Modifier... modifiers)Registers an object with a watch service. | 
WatchKey register(WatchService watcher, WatchEvent.Kind<?>[] events, WatchEvent.Modifier... modifiers) throws IOException
 If the file system object identified by this object is currently
 registered with the watch service then the watch key, representing that
 registration, is returned after changing the event set or modifiers to
 those specified by the events and modifiers parameters.
 Changing the event set does not cause pending events for the object to be
 discarded. Objects are automatically registered for the OVERFLOW event. This event is not
 required to be present in the array of events.
 
Otherwise the file system object has not yet been registered with the given watch service, so it is registered and the resulting new key is returned.
Implementations of this interface should specify the events they support.
watcher - the watch service to which this object is to be registeredevents - the events for which this object should be registeredmodifiers - the modifiers, if any, that modify how the object is registeredUnsupportedOperationException - if unsupported events or modifiers are specifiedIllegalArgumentException - if an invalid of combination of events are modifiers are specifiedClosedWatchServiceException - if the watch service is closedIOException - if an I/O error occursSecurityException - if a security manager is installed and it denies an unspecified
          permission required to monitor this object. Implementations of
          this interface should specify the permission checks.WatchKey register(WatchService watcher, WatchEvent.Kind<?>... events) throws IOException
An invocation of this method behaves in exactly the same way as the invocation
     watchable.register(watcher, events, new WatchEvent.Modifier[0]);
 watcher - the watch service to which this object is to be registeredevents - the events for which this object should be registeredUnsupportedOperationException - if unsupported events are specifiedIllegalArgumentException - if an invalid of combination of events are specifiedClosedWatchServiceException - if the watch service is closedIOException - if an I/O error occursSecurityException - if a security manager is installed and it denies an unspecified
          permission required to monitor this object. Implementations of
          this interface should specify the permission checks. Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.