| 
 | JSR 216 (Maintenance Release) | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Objectjava.lang.ThreadGroup
A thread group represents a set of threads. In addition, a thread group can also include other thread groups. The thread groups form a tree in which every thread group except the initial thread group has a parent.
A thread is allowed to access information about its own thread group, but not to access information about its thread group's parent thread group or any other thread groups.
| Constructor Summary | |
| ThreadGroup(String name)Constructs a new thread group. | |
| ThreadGroup(ThreadGroup parent,
            String name)Creates a new thread group. | |
| Method Summary | |
|  int | activeCount()Returns an estimate of the number of active threads in this thread group. | 
|  int | activeGroupCount()Returns an estimate of the number of active groups in this thread group. | 
|  void | checkAccess()Determines if the currently running thread has permission to modify this thread group. | 
|  void | destroy()Destroys this thread group and all of its subgroups. | 
|  int | enumerate(Thread[] list)Copies into the specified array every active thread in this thread group and its subgroups. | 
|  int | enumerate(Thread[] list,
          boolean recurse)Copies into the specified array every active thread in this thread group. | 
|  int | enumerate(ThreadGroup[] list)Copies into the specified array references to every active subgroup in this thread group. | 
|  int | enumerate(ThreadGroup[] list,
          boolean recurse)Copies into the specified array references to every active subgroup in this thread group. | 
|  int | getMaxPriority()Returns the maximum priority of this thread group. | 
|  String | getName()Returns the name of this thread group. | 
|  ThreadGroup | getParent()Returns the parent of this thread group. | 
|  void | interrupt()Interrupts all threads in this thread group. | 
|  boolean | isDaemon()Tests if this thread group is a daemon thread group. | 
|  boolean | isDestroyed()Tests if this thread group has been destroyed. | 
|  void | list()Prints information about this thread group to the standard output. | 
|  boolean | parentOf(ThreadGroup g)Tests if this thread group is either the thread group argument or one of its ancestor thread groups. | 
|  void | setDaemon(boolean daemon)Changes the daemon status of this thread group. | 
|  void | setMaxPriority(int pri)Sets the maximum priority of the group. | 
|  String | toString()Returns a string representation of this Thread group. | 
|  void | uncaughtException(Thread t,
                  Throwable e)Called by the Java Virtual Machine when a thread in this thread group stops because of an uncaught exception. | 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Constructor Detail | 
public ThreadGroup(String name)
 The checkAccess method of the parent thread group is 
 called with no arguments; this may result in a security exception.
name - the name of the new thread group.
SecurityException - if the current thread cannot create a
               thread in the specified thread group.checkAccess()
public ThreadGroup(ThreadGroup parent,
                   String name)
 The checkAccess method of the parent thread group is 
 called with no arguments; this may result in a security exception.
parent - the parent thread group.name - the name of the new thread group.
NullPointerException - if the thread group argument is
               null.
SecurityException - if the current thread cannot create a
               thread in the specified thread group.SecurityException, 
checkAccess()| Method Detail | 
public final String getName()
public final ThreadGroup getParent()
 First, if the parent is not null, the 
 checkAccess method of the parent thread group is 
 called with no arguments; this may result in a security exception.
null.
SecurityException - if the current thread cannot modify
               this thread group.checkAccess(), 
SecurityException, 
RuntimePermissionpublic final int getMaxPriority()
setMaxPriority(int)public final boolean isDaemon()
true if this thread group is a daemon thread group;
          false otherwise.public boolean isDestroyed()
public final void setDaemon(boolean daemon)
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
A daemon thread group is automatically destroyed when its last thread is stopped or its last thread group is destroyed.
daemon - if true, marks this thread group as
                      a daemon thread group; otherwise, marks this
                      thread group as normal.
SecurityException - if the current thread cannot modify
               this thread group.SecurityException, 
checkAccess()public final void setMaxPriority(int pri)
 First, the checkAccess method of this thread group is
 called with no arguments; this may result in a security exception.
 
 If the pri argument is less than
 Thread.MIN_PRIORITY or greater than
 Thread.MAX_PRIORITY, the maximum priority of the group
 remains unchanged.
 
 Otherwise, the priority of this ThreadGroup object is set to the
 smaller of the specified pri and the maximum permitted
 priority of the parent of this thread group. (If this thread group
 is the system thread group, which has no parent, then its maximum
 priority is simply set to pri.) Then this method is
 called recursively, with pri as its argument, for
 every thread group that belongs to this thread group.
pri - the new priority of the thread group.
SecurityException - if the current thread cannot modify
               this thread group.getMaxPriority(), 
SecurityException, 
checkAccess()public final boolean parentOf(ThreadGroup g)
g - a thread group.
true if this thread group is the thread group
          argument or one of its ancestor thread groups;
          false otherwise.public final void checkAccess()
 If there is a security manager, its checkAccess method 
 is called with this thread group as its argument. This may result 
 in throwing a SecurityException.
SecurityException - if the current thread is not allowed to
               access this thread group.SecurityManager.checkAccess(java.lang.ThreadGroup)public int activeCount()
public int enumerate(Thread[] list)
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
 An application should use the activeCount method to 
 get an estimate of how big the array should be. If the array is 
 too short to hold all the threads, the extra threads are silently 
 ignored.
list - an array into which to place the list of threads.
SecurityException - if the current thread does not
               have permission to enumerate this thread group.activeCount(), 
checkAccess()
public int enumerate(Thread[] list,
                     boolean recurse)
recurse flag is 
 true, references to every active thread in this 
 thread's subgroups are also included. If the array is too short to 
 hold all the threads, the extra threads are silently ignored. 
 
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
 An application should use the activeCount method to 
 get an estimate of how big the array should be.
list - an array into which to place the list of threads.recurse - a flag indicating whether also to include threads
                    in thread groups that are subgroups of this
                    thread group.
SecurityException - if the current thread does not
               have permission to enumerate this thread group.activeCount(), 
checkAccess()public int activeGroupCount()
public int enumerate(ThreadGroup[] list)
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
 An application should use the activeGroupCount 
 method to get an estimate of how big the array should be. If the 
 array is too short to hold all the thread groups, the extra thread 
 groups are silently ignored.
list - an array into which to place the list of thread groups.
SecurityException - if the current thread does not
               have permission to enumerate this thread group.activeGroupCount(), 
checkAccess()
public int enumerate(ThreadGroup[] list,
                     boolean recurse)
recurse flag is 
 true, references to all active subgroups of the 
 subgroups and so forth are also included. 
 
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
 An application should use the activeGroupCount 
 method to get an estimate of how big the array should be.
list - an array into which to place the list of threads.recurse - a flag indicating whether to recursively enumerate
                    all included thread groups.
SecurityException - if the current thread does not
               have permission to enumerate this thread group.activeGroupCount(), 
checkAccess()public final void interrupt()
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception. 
 
 This method then calls the interrupt method on all the 
 threads in this thread group and in all of its subgroups.
SecurityException - if the current thread is not allowed
               to access this thread group or any of the threads in
               the thread group.Thread.interrupt(), 
SecurityException, 
checkAccess()public final void destroy()
 First, the checkAccess method of this thread group is 
 called with no arguments; this may result in a security exception.
IllegalThreadStateException - if the thread group is not
               empty or if the thread group has already been destroyed.
SecurityException - if the current thread cannot modify this
               thread group.checkAccess()public void list()
public void uncaughtException(Thread t,
                              Throwable e)
 The uncaughtException method of 
 ThreadGroup does the following: 
 
uncaughtException method of that parent is called
     with the same two arguments. 
 Throwable
     argument is an instance of ThreadDeath. If so, nothing
     special is done. Otherwise, the Throwable's
     printStackTrace method is called to print a stack
     backtrace to the standard error stream.
 
 Applications can override this method in subclasses of 
 ThreadGroup to provide alternative handling of 
 uncaught exceptions.
t - the thread that is about to exit.e - the uncaught exception.System.err, 
ThreadDeath, 
Throwable.printStackTrace(java.io.PrintStream)public String toString()
toString in class Object| 
 | JSR 216 (Maintenance Release) | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||