多线程中Thread.stop()被废弃的原因:
当调用Thread.stop()方法时,该线程将释放先前其控制的所有资源,而在线程没有正常执行完毕之前强迫Stop之后,这些资源可能处在一种不一致的状态,而这些处于不一致的状态的资源被其他的线程所使用之后,就可能会发生一些意想不到的错误。
实现时间差事件的解决办法:
在主线程中设置一个状态变量,在响应线程执行时,先sleep()一个固定的时间段,之后检查主线程的这个状态,如果这个状态不同就执行不同的操作,或停止执行。
可以通过回调机制来实现响应线程对主线程变量的查看,例如:
Test.java
public class Test {
private volatile ThreadTest test;
public boolean flag = true;
public Test() {
test = new ThreadTest(this);
}
public static void main(String[] args){
Test test = new Test();
test.test.start();
test.flag = false;
test = null;
}
}
ThreadTest.java
public class ThreadTest extends Thread{
Test test;
public ThreadTest(Test test) {
this.test = test;
}
public void run() {
try{
sleep(1000);
if (test.flag)
System.out.println("I've waken up!");
}catch(Exception e){
e.printStackTrace();
}
}
}
当调用Thread.stop()方法时,该线程将释放先前其控制的所有资源,而在线程没有正常执行完毕之前强迫Stop之后,这些资源可能处在一种不一致的状态,而这些处于不一致的状态的资源被其他的线程所使用之后,就可能会发生一些意想不到的错误。
实现时间差事件的解决办法:
在主线程中设置一个状态变量,在响应线程执行时,先sleep()一个固定的时间段,之后检查主线程的这个状态,如果这个状态不同就执行不同的操作,或停止执行。
可以通过回调机制来实现响应线程对主线程变量的查看,例如:
Test.java
public class Test {
private volatile ThreadTest test;
public boolean flag = true;
public Test() {
test = new ThreadTest(this);
}
public static void main(String[] args){
Test test = new Test();
test.test.start();
test.flag = false;
test = null;
}
}
ThreadTest.java
public class ThreadTest extends Thread{
Test test;
public ThreadTest(Test test) {
this.test = test;
}
public void run() {
try{
sleep(1000);
if (test.flag)
System.out.println("I've waken up!");
}catch(Exception e){
e.printStackTrace();
}
}
}
博客介绍了Java多线程中Thread.stop()被废弃的原因,调用该方法会使线程释放资源,可能导致资源状态不一致,被其他线程使用后易出错。还给出实现时间差事件的解决办法,在主线程设状态变量,响应线程sleep后检查状态,可通过回调机制查看,文中给出示例代码。

被折叠的 条评论
为什么被折叠?



