打字猴:1.700449959e+09
1700449959
1700449960 t1.interrupt();
1700449961
1700449962 }
1700449963
1700449964 执行这段代码,你会发现一直有Running在输出,永远不会停止,似乎执行了interrupt没有任何变化,那是因为interrupt方法不能终止一个线程状态,它只会改变中断标志位(如果在t1.interrupt()前后输出t1.isInterrupted()则会发现分别输出了false和true),如果需要终止该线程,还需要自行进行判断,例如我们可以使用interrupt编写出更加简洁、安全的终止线程代码:
1700449965
1700449966 class SafeStopThread extends Thread{
1700449967
1700449968 @Override
1700449969
1700449970 public void run(){
1700449971
1700449972 //判断线程体是否运行
1700449973
1700449974 while(!isInterrupted()){
1700449975
1700449976 //Do Something
1700449977
1700449978 }
1700449979
1700449980 }
1700449981
1700449982 }
1700449983
1700449984 总之,如果期望终止一个正在运行的线程,则不能使用已经过时的stop方法,需要自行编码实现,如此即可保证原子逻辑不被破坏,代码逻辑不会出现异常。当然,如果我们使用的是线程池(比如ThreadPoolExecutor类),那么可以通过shutdown方法逐步关闭池中的线程,它采用的是比较温和、安全的关闭线程方法,完全不会产生类似stop方法的弊端。
1700449985
1700449986
1700449987
1700449988
1700449989 编写高质量代码:改善Java程序的151个建议 [:1700438196]
1700449990 编写高质量代码:改善Java程序的151个建议 建议121:线程优先级只使用三个等级
1700449991
1700449992 线程的优先级(Priority)决定了线程获得CPU运行的机会,优先级越高获得的运行机会越大,优先级越低获得的机会越小。Java的线程有10个级别(准确地说是11个级别,级别为0的线程是JVM的,应用程序不能设置该级别),那是不是说级别是10的线程肯定比级别为9的线程先运行呢?我们来看如下一个多线程类:
1700449993
1700449994 class TestThread implements Runnable{
1700449995
1700449996 //启动线程
1700449997
1700449998 public void start(int_priority){
1700449999
1700450000 Thread t=new Thread(this);
1700450001
1700450002 //设置线程优先级
1700450003
1700450004 t.setPriority(_priority);
1700450005
1700450006 t.start();
1700450007
1700450008 }
[ 上一页 ]  [ :1.700449959e+09 ]  [ 下一页 ]