zoukankan      html  css  js  c++  java
  • 安全的终止线程的两种方法

    过期的suspend()、resume()、stop()

    不建议使用这三个函数来停止线程,以suspend()方法为例,在调用后,线程不会释放已经占有的资源(比如锁),而是占有着资源进入睡眠状态,这样容易引起死锁问题。同样,stop()方法在终结一个线程是不会保证线程的资源正常释放,通常识没有给予线程完成资源释放工作的机会,因此会导致程序可能工作在不确定的状态下。

    两种安全终止线程的方法

    package test;
    
    import java.util.concurrent.TimeUnit;
    
    public class ShowDownThread {
    private static class TargetRunnable implements Runnable{
    	private boolean isCancel = false; //自定义一个终止标志位;
    	private long  i;
    	@Override
    	public void run() {
    		// TODO Auto-generated method stub
    		while(!isCancel&&!Thread.currentThread().isInterrupted()) {
    			i++;
    		}
    		System.out.println("Count i="+i);
    	}
    	
    	public void cancel() {
    		isCancel =true;
    	}
    	
    }
    public static void main(String[] args) throws InterruptedException {
    	TargetRunnable  runnable = new TargetRunnable();
    	Thread thread = new Thread(runnable,"CounThread");
    	thread.start();
    	TimeUnit.SECONDS.sleep(1);  //底层是调用的 Thread.sleep(ms, ns);
    	thread.interrupt();// Just to set the interrupt flag;
    	
    	TargetRunnable runnable1 = new TargetRunnable();
    	Thread thread1 = new Thread(runnable1,"CountThread1");
    	thread1.start();
    	TimeUnit.SECONDS.sleep(1);
    	runnable1.cancel();
    	
    	
    }
    }
    
    

    运行结果

    两种方式,一是调用interrupt()方法,其实这也是一种中断标志的方式;二是自己在线程中自定义一个标志位;

    多思考,多尝试。
  • 相关阅读:
    Lookup 组件用法全解
    将字符串转换成表
    处于同一域中的两台SQL Server 实例无法连接
    在SSIS中的不同组件间使用局部临时表
    SSIS的CheckPoint用法
    控制流如何处理错误
    SSIS 对数据排序
    SSIS 数据输出列因为字符截断而失败
    SQL Server 的本地时间和UTC时间
    TSQL Merge 用法
  • 原文地址:https://www.cnblogs.com/LynnMin/p/9481485.html
Copyright © 2011-2022 走看看