Java多线程生命周期

这两天在看线程的东西,根据牛人的博客总结了一些:每个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

时间: 2024-10-13 17:40:24

Java多线程生命周期的相关文章

java类生命周期详细解析

(一)详解java类的生命周期 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大多只是告诉你“怎样做”,但至于“为什么这样做”却不多说,所以造成大家在基础和原理方面的知识比较匮乏,所以笔者今天就斗胆来讲一下这个问题,权当抛砖引玉,希望对在这个问题上有疑惑的朋友有所帮助,文中有说的不对的地方,也希望各路高手前来指正. 首先来了解一下jvm(java虚拟机)

hibernate session缓存和java对象生命周期

一.java对象生命周期 1.在java中,使用new关键字,创建一个java对象,jvm就为这个对象分配一块内存空间.只要这个变量被引用,他就一直存在于内存中.如果没有被任何变量引用(包括间接引用),那么这个对象就会被垃圾回收器回收.下面用一段代码来解释: Customer c=new Customer(); Order o1=new Order(); Order 02=new Order(); o1.setCustomer(c); c.getOrders().add(o1); o1=null

Java学习之==>Java线程生命周期与状态切换

一.Java线程生命周期与状态切换 这些状态的描述可以总结成下图: NEW 一个刚创建但尚未启动的Java线程实例就是处于 NEW 状态 public class App { public static void main(String[] args) { Thread thread = new Thread(); Thread.State state = thread.getState(); System.out.println(state); } } // 输出结果 NEW RUNNABLE

Java 线程生命周期

2.线程的生命周期 与人有生老病死一样,线程也同样要经历开始(等待).运行.挂起和停止四种不同的状态.这四种状态都可以通过Thread类中的方法进行控制.下面给出了Thread类中和这四种状态相关的方法. // 开始线程 publicvoid start( ); publicvoid run( ); // 挂起和唤醒线程 publicvoid resume( );     // 不建议使用 publicvoid suspend( );    // 不建议使用 publicstaticvoid s

Java实现生命周期管理机制

先扯再说 最近一直在研究某个国产开源的MySQL数据库中间件,拉下其最新版的代码到eclipse后,启动起来,然后做各种测试和代码追踪:用完想要关闭它时,拉出它的STOP类想要运行时,发现这个类里赫然只写以下几行代码,于是我感觉瞬间受到了很多伤害. public static void main(String[] args) { System.out.println(new Date() + ",server shutdown!"); } 这个中间件启动和运行的时候,开启了监听,启动着

java对象生命周期

java中一个对象的完整生命周期涉及java平台的很多技术.在创建一个java对象之前,需要先由虚拟机加载该类,然后对该java类进行链接和初始化.初始化完成之后,才创建出该类的对象实例.java对象也有自己的初始化过程,主要通过构造方法完成.当不再有引用指向该对象时,对象占用的内存会在合适的时机被垃圾回收器回收.对象终止机制提供了一种方式在对象被回收之前进行清理工作. java类的链接 虚拟机刚启动时,内部只包含java核心类的相关信息.随着程序的运行,不断有新的java类被加载到虚拟机中.j

Java WebSocket生命周期

本章将讲述WebSocket端点的生命周期.WebSocket端点的生命周期为开发人员提供了一个框架来管理端点所需要的资源,也提供了一个框架来拦截消息.我们将仔细探讨其生命周期的顺序和语义,以及Java WebSocket API如何提供API和注解来支持处理这些事件. 一.WebSocket协议 与基于HTTP的技术不同,WebSocket具有生命周期.此生命周期周期由WebSocket协议支撑.WebSocket协议定义了客户端和服务器长时间存活的专用的TCP连接,一旦连接已经建立,数据的传

java static 生命周期和作用域

类的成员变量有两种:一种是被static关键字修饰的变量,叫类变量或静态变量,一种是没有被static修饰的,叫做实例变量 在语法定义上的区别:静态变量前要加static关键字,而实例变量前则不加. 在程序运行时的区别:实例变量属于某个对象的属性,必须创建了实例对象,其中的实例变量才会被分配空间,才能使用这个实例变量. 静态变量不属于某个实例对象,而是属于类,所以也称为类变量,只要程序加载了类的字节码,不用创建任何实例对象 静态变量就会被分配空间,静态变量就可以被使用了.总之,实例变量必须创建对

Oracle 宣布 Java 7 生命周期终结

快速使用Romanysoft LAB的技术实现 HTML 开发Mac OS App,并销售到苹果应用商店中. <HTML开发Mac OS App 视频教程> 土豆网同步更新:http://www.tudou.com/plcover/VHNh6ZopQ4E/ 百度网盘同步:http://pan.baidu.com/s/1jG1Q58M 分享  [中文纪录片]互联网时代   http://pan.baidu.com/s/1qWkJfcS 官方QQ群:(申请加入,说是我推荐的) App实践出真知 4