这一章节我们来讨论一下暴力Stop方法。
1.使用例子
package com.ray.deepintothread.ch01.topic_8; public class StopByStopMethod { @SuppressWarnings("deprecation") public static void main(String[] args) throws InterruptedException { ThreadFive threadFive = new ThreadFive(); threadFive.start(); Thread.sleep(200); threadFive.stop(); } } class ThreadFive extends Thread { @Override public void run() { System.out.println("------------begin-------------"); try { System.out.println("------------working-------------"); sleep(2000); } catch (InterruptedException e) { System.out.println("------------exit-------------"); } super.run(); } }
------------begin-------------
------------working-------------
2.这是一个java弃用的方法,使用它的时候存在重大隐患
下面是引用java的api里面的原文
* Forces the thread to stop executing. * <p> * If there is a security manager installed, its <code>checkAccess</code> * method is called with <code>this</code> * as its argument. This may result in a * <code>SecurityException</code> being raised (in the current thread). * <p> * If this thread is different from the current thread (that is, the current * thread is trying to stop a thread other than itself), the * security manager's <code>checkPermission</code> method (with a * <code>RuntimePermission("stopThread")</code> argument) is called in * addition. * Again, this may result in throwing a * <code>SecurityException</code> (in the current thread). * <p> * The thread represented by this thread is forced to stop whatever * it is doing abnormally and to throw a newly created * <code>ThreadDeath</code> object as an exception. * <p> * It is permitted to stop a thread that has not yet been started. * If the thread is eventually started, it immediately terminates. * <p> * An application should not normally try to catch * <code>ThreadDeath</code> unless it must do some extraordinary * cleanup operation (note that the throwing of * <code>ThreadDeath</code> causes <code>finally</code> clauses of * <code>try</code> statements to be executed before the thread * officially dies). If a <code>catch</code> clause catches a * <code>ThreadDeath</code> object, it is important to rethrow the * object so that the thread actually dies. * <p> * The top-level error handler that reacts to otherwise uncaught * exceptions does not print out a message or otherwise notify the * application if the uncaught exception is an instance of * <code>ThreadDeath</code>.
(1)当程序调用security manager的时候,会额外的执行checkPermission方法
(2)当程序调用security manager,会抛出SecurityException这种安全异常
(3)隐式抛ThreadDeath异常
(4)允许stop那些还没有开始的线程
(5)即便那些线程启动了,也会立刻终止
等等,还有几个
因此,这个方法最终被java弃用。
我们来演示一下第三个原因,因为其他的几个比较难通过一个例子就能够说清楚。
package com.ray.deepintothread.ch01.topic_8; public class CatchThreadDeath { public static void main(String[] args) throws InterruptedException { ThreadOne threadOne = new ThreadOne(); threadOne.start(); Thread.sleep(200); } } class ThreadOne extends Thread { @SuppressWarnings("deprecation") @Override public void run() { try { this.stop(); } catch (ThreadDeath e) { System.out.println(e); } super.run(); } }
java.lang.ThreadDeath
总结:这一章节我们来讨论了一下暴力stop线程,然后描述了一下他的原因。
我的github:https://github.com/raylee2015/DeepIntoThread