Java中的线程Thread方法之---suspend()和resume()
来源:互联网 发布:淘宝top排行榜在哪里 编辑:程序博客网 时间:2024/05/16 00:45
前篇说到了Thread中的join方法,这一篇我们就来介绍一下suspend()和resume()方法,从字面意义上可以了解到这两个方法是一对的,suspend()方法就是将一个线程挂起(暂停),resume()方法就是将一个挂起线程复活继续执行。首先看一个例子:
package com.threadstop.demo;import java.util.Iterator;import java.util.Map;import java.util.Map.Entry;import java.util.Set;/** * @author weijiang204321 *说明: *调用了suspend方法,将t0线程挂起,但是出现的问题是,t0.suspend方法之后的代码不执行了,搞了半天终于知道为什么了, *因为在t0里面使用了System.out.println方法了,查看println方法的源代码发现他是个同步的方法,加锁了,这个锁是哪个呢? *对就是PrintStream,在Main中的printCurrentAliveThread方法中用到了System.out.println方法,打断点才知道 *搞了半天阻塞在这里了,因为我们知道suspend方法是不释放锁的,所以导致会阻塞在println方法中,但是有一个前提是t0线程和main线程 *的println方法中拿到的是同一个锁,这时候在看一下System.out变量时一个static PrintStream,这时候就明了了,因为是static *所以对象是相同的,这两个线程拿到的System.out是同一个对象,所以这两个线程也是拿到的是相同的锁的。 * */public class ThreadStopLock {public static void main(String[] args) {try {//定义线程Thread t0 = new Thread() {public void run() {try {for(long i=0;i<1000*1000*10;i++){System.out.println(i);}System.out.println("thread death");} catch (Throwable ex) {System.out.println("Caught in run: " + ex);ex.printStackTrace();}}};//开启线程t0.start();//等待2s之后挂起线程t0Thread.sleep(2*1000);//挂起线程t0.suspend();//打印当前的所有线程printCurrentAliveThread();//等待2s之后恢复线程Thread.sleep(2*1000);//复活线程t0.resume();} catch (Throwable t) {System.out.println("Caught in main: " + t);t.printStackTrace();}}/** * 打印当前线程 */public static void printCurrentAliveThread(){Map<Thread, StackTraceElement[]> maps = Thread.getAllStackTraces();Set<Entry<Thread, StackTraceElement[]>> set = maps.entrySet();Iterator<Entry<Thread,StackTraceElement[]>> iterator = set.iterator();System.out.println("System Alive Thread List:");System.out.println("-------------------------");while(iterator.hasNext()){System.out.println("AliveThread_Name:"+iterator.next().getKey().getName());}System.out.println("-------------------------");}}代码很简单的,定义一个线程,在线程中进行打印,在主线程中的逻辑是,先开启线程t0进行打印数据,等待2s之后将挂起线程t0,然后打印一下当前的活跃线程,然后再等待2s之后再复活t0线程继续打印!
但是结果不尽人意呀,结果很是惊讶的!运行结果:
好吧,开始打印,打印到311800(当然这个不是一定的),就停止了,但是这一停止不是停2s呀,是一直停着,这不是明显的死锁吗?导致t0.suspend后面的代码都不执行了,这就郁闷了,这个是为什么呢?纠结了一下午,打断点的时候才知道为什么,断点停在方法printCurrentAliveThread中的System.out.println()这行代码上,那就可以断定了,发生死锁的原因可能就是System.out.println方法,查看源代码:
public void println(String x) { synchronized (this) { print(x); newLine(); } }这个是PrintStream对象中的println方法,是个同步锁的方法,这时候应该就明白了,那么这个锁是什么呢?没错,这个所就是PrintStream对象,因为在t0线程中也有System.out.println,当调用suspend()方法调用的时候,这个方法是不会释放锁的,当然这个锁是同一个的,为什么呢?看一下System类中的out变量定义:
public final static PrintStream out = null;是static类型的,所以他是类上面的锁,肯定是同一个锁了,所以发生了死锁,
这时候我们将printCurrentAliveThread方法注释之后,运行就没有任何问题了。
就写到这里吧,好累,后面还有哦,继续关注吧!
4 0
- Java中的线程Thread方法之---suspend()和resume()
- Java中的线程Thread方法之suspend()和resume()
- Java中的线程Thread方法之---suspend()和resume()
- java 线程Thread方法之suspend()和resume()
- 线程之suspend和resume方法
- java 线程中suspend,resume方法独占
- 为何java里的Thread类的方法suspend()和resume()不推荐使用?
- java中线程阻塞之sleep、suspend、join、wait、resume、notify方法解析(一)
- 为什么java线程不推荐调用stop,suspend,resume方法
- 为什么线程会放弃Suspend和Resume方法
- 【多线程-Suspend()和Resume()方法】
- Java多线程之线程的挂起与恢复(Suspend/Resume)
- java线程暂停与恢复suspend和resume
- Java并发编程系列之六:stop()、resume()和suspend()
- Java并发编程系列之八:stop()、resume()和suspend()
- java thread的stop,suspend,resume等方法废弃的原因
- 我爱学Java之Thread中stop(),suspend(),resume()为什么不安全
- Chapter 4 suspend和resume方法
- Java Ant build.xml详解
- 安卓环境配置
- jmx入门及开发示例
- Flex Base64 md5 123456后得到4QrcOUm6Wau+VuBX8g+IPg==
- HDU 1270
- Java中的线程Thread方法之---suspend()和resume()
- HTML5画布文本标准教程
- c#中的接口
- 中国用户使用代理软件的分析
- 消息机制--ProgressBar
- objective -c 第一节
- Silverlight Export DataGrid Data
- 蓝桥杯 最短路
- 新年里的那些怪事儿