您的位置:首页 > 编程语言 > Java开发

Java多线程生命周期

2015-06-14 17:26 531 查看
这两天在看线程的东西,根据牛人的博客总结了一些:每个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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: