首页 > 代码库 > Thread类详解

Thread类详解

java.lang
类 Thread

java.lang.Object  

继承者

java.lang.Thread
所有已实现的接口:
Runnable

public class Threadextends Objectimplements Runnable

线程 是程序中的执行线程。Java 虚拟机允许应用程序并发地运行多个执行线程。

每个线程都有一个优先级,高优先级线程的执行优先于低优先级线程。每个线程都可以或不可以标记为一个守护程序。当某个线程中运行的代码创建一个新 Thread 对象时,该新线程的初始优先级被设定为创建线程的优先级,并且当且仅当创建线程是守护线程时,新线程才是守护程序。

当 Java 虚拟机启动时,通常都会有单个非守护线程(它通常会调用某个指定类的 main 方法)。Java 虚拟机会继续执行线程,直到下列任一情况出现时为止:

  • 调用了 Runtime 类的 exit 方法,并且安全管理器允许退出操作发生。
  • 非守护线程的所有线程都已停止运行,无论是通过从对 run 方法的调用中返回,还是通过抛出一个传播到 run 方法之外的异常。

创建新执行线程有两种方法。一种方法是将类声明为 Thread 的子类。该子类应重写 Thread 类的 run 方法。接下来可以分配并启动该子类的实例。例如,计算大于某一规定值的质数的线程可以写成:

 


     class PrimeThread extends Thread {         long minPrime;         PrimeThread(long minPrime) {             this.minPrime = minPrime;         }          public void run() {             // compute primes larger than minPrime              . . .         }     } 

然后,下列代码会创建并启动一个线程:

 

     PrimeThread p = new PrimeThread(143);     p.start(); 

创建线程的另一种方法是声明实现 Runnable 接口的类。该类然后实现 run 方法。然后可以分配该类的实例,在创建 Thread 时作为一个参数来传递并启动。采用这种风格的同一个例子如下所示:

 


     class PrimeRun implements Runnable {         long minPrime;         PrimeRun(long minPrime) {             this.minPrime = minPrime;         }          public void run() {             // compute primes larger than minPrime              . . .         }     } 

然后,下列代码会创建并启动一个线程:

 

     PrimeRun p = new PrimeRun(143);     new Thread(p).start(); 

每个线程都有一个标识名,多个线程可以同名。如果线程创建时没有指定标识名,就会为其生成一个新名称。

 

 

从以下版本开始:
JDK1.0
另请参见:
Runnable, Runtime.exit(int), run(), stop()

嵌套类摘要
static classThread.State
线程状态。
static interfaceThread.UncaughtExceptionHandler
Thread 因未捕获的异常而突然终止时,调用处理程序的接口。
字段摘要
static intMAX_PRIORITY
线程可以具有的最高优先级。
static intMIN_PRIORITY
线程可以具有的最低优先级。
static intNORM_PRIORITY
分配给线程的默认优先级。
构造方法摘要
Thread()
分配新的 Thread 对象。
Thread(Runnable target)
分配新的 Thread 对象。
Thread(Runnable target, String name)
分配新的 Thread 对象。
Thread(String name)
分配新的 Thread 对象。
Thread(ThreadGroup group, Runnable target)
分配新的 Thread 对象。
Thread(ThreadGroup group, Runnable target, String name)
分配新的 Thread 对象,以便将 target 作为其运行对象,将指定的 name 作为其名称,并作为 group 所引用的线程组的一员。
Thread(ThreadGroup group, Runnable target, String name, long stackSize)
分配新的 Thread 对象,以便将 target 作为其运行对象,将指定的 name 作为其名称,作为 group 所引用的线程组的一员,并具有指定的堆栈大小
Thread(ThreadGroup group, String name)
分配新的 Thread 对象。
方法摘要
static intactiveCount()
返回当前线程的线程组中活动线程的数目。
voidcheckAccess()
判定当前运行的线程是否有权修改该线程。
intcountStackFrames()
已过时。 该调用的定义依赖于 suspend(),但它遭到了反对。此外,该调用的结果从来都不是意义明确的。
static ThreadcurrentThread()
返回对当前正在执行的线程对象的引用。
voiddestroy()
已过时。 该方法最初用于破坏该线程,但不作任何清除。它所保持的任何监视器都会保持锁定状态。不过,该方法决不会被实现。即使要实现,它也极有可能以 suspend() 方式被死锁。如果目标线程被破坏时保持一个保护关键系统资源的锁,则任何线程在任何时候都无法再次访问该资源。如果另一个线程曾试图锁定该资源,则会出现死锁。这类死锁通常会证明它们自己是“冻结”的进程。有关更多信息,请参阅为何不赞成使用 Thread.stop、Thread.suspend 和 Thread.resume?。
static voiddumpStack()
将当前线程的堆栈跟踪打印至标准错误流。
static intenumerate(Thread[] tarray)
将当前线程的线程组及其子组中的每一个活动线程复制到指定的数组中。
static Map<Thread,StackTraceElement[]>getAllStackTraces()
返回所有活动线程的堆栈跟踪的一个映射。
ClassLoadergetContextClassLoader()
返回该线程的上下文 ClassLoader。
static Thread.UncaughtExceptionHandlergetDefaultUncaughtExceptionHandler()
返回线程由于未捕获到异常而突然终止时调用的默认处理程序。
longgetId()
返回该线程的标识符。
StringgetName()
返回该线程的名称。
intgetPriority()
返回线程的优先级。
StackTraceElement[]getStackTrace()
返回一个表示该线程堆栈转储的堆栈跟踪元素数组。
Thread.StategetState()
返回该线程的状态。
ThreadGroupgetThreadGroup()
返回该线程所属的线程组。
Thread.UncaughtExceptionHandlergetUncaughtExceptionHandler()
返回该线程由于未捕获到异常而突然终止时调用的处理程序。
static booleanholdsLock(Object obj)
当且仅当当前线程在指定的对象上保持监视器锁时,才返回 true
voidinterrupt()
中断线程。
static booleaninterrupted()
测试当前线程是否已经中断。
booleanisAlive()
测试线程是否处于活动状态。
booleanisDaemon()
测试该线程是否为守护线程。
booleanisInterrupted()
测试线程是否已经中断。
voidjoin()
等待该线程终止。
voidjoin(long millis)
等待该线程终止的时间最长为 millis 毫秒。
voidjoin(long millis, int nanos)
等待该线程终止的时间最长为 millis 毫秒 + nanos 纳秒。
voidresume()
已过时。 该方法只与 suspend() 一起使用,但 suspend() 已经遭到反对,因为它具有死锁倾向。有关更多信息,请参阅为何不赞成使用 Thread.stop、Thread.suspend 和 Thread.resume?。
voidrun()
如果该线程是使用独立的 Runnable 运行对象构造的,则调用该 Runnable 对象的 run 方法;否则,该方法不执行任何操作并返回。
voidsetContextClassLoader(ClassLoader cl)
设置该线程的上下文 ClassLoader。
voidsetDaemon(boolean on)
将该线程标记为守护线程或用户线程。
static voidsetDefaultUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh)
设置当线程由于未捕获到异常而突然终止,并且没有为该线程定义其他处理程序时所调用的默认处理程序。
voidsetName(String name)
改变线程名称,使之与参数 name 相同。
voidsetPriority(int newPriority)
更改线程的优先级。
voidsetUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh)
设置该线程由于未捕获到异常而突然终止时调用的处理程序。
static voidsleep(long millis)
在指定的毫秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。
static voidsleep(long millis, int nanos)
在指定的毫秒数加指定的纳秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。
voidstart()
使该线程开始执行;Java 虚拟机调用该线程的 run 方法。
voidstop()
已过时。 该方法具有固有的不安全性。用 Thread.stop 来终止线程将释放它已经锁定的所有监视器(作为沿堆栈向上传播的未检查 ThreadDeath 异常的一个自然后果)。如果以前受这些监视器保护的任何对象都处于一种不一致的状态,则损坏的对象将对其他线程可见,这有可能导致任意的行为。stop 的许多使用都应由只修改某些变量以指示目标线程应该停止运行的代码来取代。目标线程应定期检查该变量,并且如果该变量指示它要停止运行,则从其运行方法依次返回。如果目标线程等待很长时间(例如基于一个条件变量),则应使用 interrupt 方法来中断该等待。有关更多信息,请参阅为何不赞成使用 Thread.stop、Thread.suspend 和 Thread.resume?。
voidstop(Throwable obj)
已过时。 该方法具有固有的不安全性。有关详细信息,请参阅 stop()。该方法的附加危险是它可用于生成目标线程未准备处理的异常(包括若没有该方法该线程不太可能抛出的已检查的异常)。有关更多信息,请参阅为何不赞成使用 Thread.stop、Thread.suspend 和 Thread.resume?。
voidsuspend()
已过时。 该方法已经遭到反对,因为它具有固有的死锁倾向。如果目标线程挂起时在保护关键系统资源的监视器上保持有锁,则在目标线程重新开始以前任何线程都不能访问该资源。如果重新开始目标线程的线程想在调用 resume 之前锁定该监视器,则会发生死锁。这类死锁通常会证明自己是“冻结”的进程。有关更多信息,请参阅为何不赞成使用 Thread.stop、Thread.suspend 和 Thread.resume?。
StringtoString()
返回该线程的字符串表示形式,包括线程名称、优先级和线程组。
static voidyield()
暂停当前正在执行的线程对象,并执行其他线程。

从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait

Thread类详解