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://img.blog.csdn.net/20150614172952223?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbWFveWVxaXU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
原文链接: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
: 它的作用是启动一个新线程,新线程会执行相应的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
相关文章推荐
- java 代码动态注入
- JDK之包装器类源码的分析
- struts.xml 配置、注释
- spring源码初步学习-容器(BeanFactory)基本实现
- Java后台发送Post请求,数据传输格式JSON
- 深入理解java垃圾回收机制----
- java 框架基础知识(2)----动态代理-->Spring AOP
- 走进Struts2(二) — Struts2的基石(拦截器)
- 关于springmvc怎么完成中文字符的接收问题
- 关于springmvc怎么自动把前台string类型日期字段转换成date类型
- Java输入/输出流
- 关于springmvc配置文件放在非默认位置
- Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
- Java集合之Map
- Spring 框架的设计理念与设计模式分析
- java怎么接受键盘输入
- SpringMVC简明教程(二)——传参
- 详解Java反射机制
- Idea 编译报错 javacTask: 源发行版 1.6 需要目标发行版 1.6
- java笔记14 包