这两天在看线程的东西,根据牛人的博客总结了一些:每个Java程序至少包含一个线程:主线程。其它线程都是通过Thread构造器或实例化继承类Thread的类来创建的。正在运行的线程通常是由操作系统创建的;Thread对象是由JavaVM创建的,在一个线程对新线程的Thread对象调用start()方法之前,这个新线程并没有真正开始执行。Thread对象在其线程真正启动之前就已经存在了,而且其线程退出之后仍然存在。另外需要说明的是:run()方法只是一个类中的普通方法,直接执行和普通的方法没有两样;start()方法则不同,它首先做了创建线程(初始化)等一系列工作,然后该线程由线程调度器控制获得虚拟cpu后,在jvm上运行run方法,仅仅是将线程送入runnable然后调用run()方法,执行线程体。总结起来就是:start()
: 它的作用是启动一个新线程,新线程会执行相应的run()方法。start()不能被重复调用。run() : run()就和普通的成员方法一样,可以被重复调用。单独调用run()的话,会在当前线程中执行run(),而并不会启动新线程!
线程的生命周期可分为四个状态:
创建状态
使用new操作符创建新的线程类对象时,该线程处于创建状态。
处于创建状态的线程只是一个对象,系统还没有为其分配资源。
可运行状态
执行线程的start()方法,为线程分配系统资源,安排其运行,并调用其run()方法,这样就使线程进入可运行状态了。
可运行状态并不一定表示运行中。
不可运行状态
当发生下列事件时,处于运行状态的线程将进入不可运行状态:
调用sleep()方法,使线程进入睡眠状态
调用yield()方法,让出CPU的占用权
线程调用wait方法等待特定条件满足
线程IO阻塞
另一个更高优先级的线程出现
在支持时间片的系统中,线程的时间片用完
调用了synchronized方法或者synchronized同步代码块使得对象被锁
yield
public static void yield()
暂停当前正在执行的线程对象,并执行其他线程。
返回可运行状态
处于睡眠状态的线程在指定的睡眠事件之后
如果线程正在等待某一条件,另一对象必须使用notify()或notifyAll()方法通知等待线程
如果线程因为IO阻塞,则等待IO操作完成之后返回可运行状态
调用了synchronized方法,则等待方法执行完成进行解锁
消亡状态
当run方法执行结束后,进入消亡状态。
原文链接:http://developer.51cto.com/art/200906/130139.htm
http://www.itzhai.com/java-based-notebook-the-life-cycle-of-thread-priorities-and-thread-status-of-common-method.html