JAVA多线程之线程的挂起与恢复(suspend方法与resume方法)
2016-04-30 22:53
417 查看
一,介绍
本文讨论JAVA多线程中,使用 thread.suspend()方法暂停线程,使用 thread.resume()恢复暂停的线程 的特点。
先介绍二个关于线程的基本知识:
①线程的执行体是run()方法里面的每一条语句,main线程执行的则是main()方法里面的语句。
②Thread.sleep()方法 使当前正在执行的线程睡眠。
二,suspend()方法
①当某个线程的suspend()方法被调用时,该线程会被挂起。如果该线程占有了锁,则它不会释放锁。即,线程在挂起的状态下还持有锁。
②suspend()已经是一个过时的方法了。
来分析一段代码:
在第8行,睡眠的线程是main线程。这样第7行启动的线程'thread'就有机会获得CPU执行,于是:MyThread类的run()方法中的代码就执行了。
当main线程睡眠了1秒钟并重新获得了CPU执行时,执行到第9行。
在第9行,让 第7行中启动的线程 suspend(挂起)。
于是,'thread'线程就不会再打印i的值了。然后,main线程继续执行到第10行,准备打印"main end!"
但是,由于System.out.println(...),它是一个同步方法,PrintOut的println(Object o)的源代码如下:
可以看出,在第12行,需要先获得当前PrintOut对象的锁。
而由于此时,MyThread类的线程'thread'是挂起的。它的run()方法里面也有打印语句。因此,它占有的PrintOut的对象锁没有释放。
从而导致main线程无法执行Run.java中的第10行,打印输出语句。
注意 PrintOut是System类中的一个静态属性,System类中只有唯一的一个PrintOut对象,System类中相关源代码如下:
三,resume()方法
该方法很功能很简单,就是恢复 因suspend()方法挂起的线程,使之重新能够获得CPU执行。
本文讨论JAVA多线程中,使用 thread.suspend()方法暂停线程,使用 thread.resume()恢复暂停的线程 的特点。
先介绍二个关于线程的基本知识:
①线程的执行体是run()方法里面的每一条语句,main线程执行的则是main()方法里面的语句。
②Thread.sleep()方法 使当前正在执行的线程睡眠。
二,suspend()方法
①当某个线程的suspend()方法被调用时,该线程会被挂起。如果该线程占有了锁,则它不会释放锁。即,线程在挂起的状态下还持有锁。
②suspend()已经是一个过时的方法了。
来分析一段代码:
public class MyThread extends Thread { private long i = 0; public long getI() { return i; } public void setI(long i) { this.i = i; } @Override public void run() { while (true) { i++; System.out.println(i);//同步方法 } } }
public class Run { public static void main(String[] args) { try { MyThread thread = new MyThread(); thread.start();//启动一个线程'thread' Thread.sleep(1000);//使当前线程(main线程)睡眠 thread.suspend();//挂起线程'thread' System.out.println("main end!"); } catch (InterruptedException e) { e.printStackTrace(); } } }
在第8行,睡眠的线程是main线程。这样第7行启动的线程'thread'就有机会获得CPU执行,于是:MyThread类的run()方法中的代码就执行了。
当main线程睡眠了1秒钟并重新获得了CPU执行时,执行到第9行。
在第9行,让 第7行中启动的线程 suspend(挂起)。
于是,'thread'线程就不会再打印i的值了。然后,main线程继续执行到第10行,准备打印"main end!"
但是,由于System.out.println(...),它是一个同步方法,PrintOut的println(Object o)的源代码如下:
/** * Prints an Object and then terminate the line. This method calls * at first String.valueOf(x) to get the printed object's string value, * then behaves as * though it invokes <code>{@link #print(String)}</code> and then * <code>{@link #println()}</code>. * * @param x The <code>Object</code> to be printed. */ public void println(Object x) { String s = String.valueOf(x); synchronized (this) { print(s); newLine(); } }
可以看出,在第12行,需要先获得当前PrintOut对象的锁。
而由于此时,MyThread类的线程'thread'是挂起的。它的run()方法里面也有打印语句。因此,它占有的PrintOut的对象锁没有释放。
从而导致main线程无法执行Run.java中的第10行,打印输出语句。
注意 PrintOut是System类中的一个静态属性,System类中只有唯一的一个PrintOut对象,System类中相关源代码如下:
/** * The "standard" output stream. This stream is already * open and ready to accept output data. Typically this stream * corresponds to display output or another output destination * specified by the host environment or user. * <p> * For simple stand-alone Java applications, a typical way to write * a line of output data is: * <blockquote><pre> * System.out.println(data) * </pre></blockquote> * <p> * See the <code>println</code> methods in class <code>PrintStream</code>. */ public final static PrintStream out = null;
三,resume()方法
该方法很功能很简单,就是恢复 因suspend()方法挂起的线程,使之重新能够获得CPU执行。
相关文章推荐
- Struts1+Spring+Hibernate整合
- Spring Boot 属性配置和使用
- Spring Boot 属性配置和使用
- Java web之统计站点被访问的次数
- 大量JAVA系列教学视频免费学习
- 求高精度幂(java)
- Java中的数学类
- Java 作业2 Java API
- Java对象死亡标记的过程
- 启动 Eclipse 弹出“Failed to load the JNI shared library jvm.dll”
- Java Swing中Substance个人比较喜欢的两种组合
- [转载]企业级应用架构(NHibernater+Spring.Net+MVC3)
- 【JAVA】java字符串拼接
- 初识spring mvc + mybatis
- JAVA为什么要配置环境变量,怎样配置
- 第91课:SparkStreaming基于Kafka Direct案例实战和内幕源码解密 java.lang.ClassNotFoundException 踩坑解决问题详细内幕版本
- Java多线程通信方式
- java消息机制 ActiveMQ入门实例
- 【Struts】:Interceptors(拦截器)
- java中输入流和输出流