1.7.2判断线程是否是停止状态

判断线程是否停止的状态

Thread.java类里面提供了两种方法。

1)this.interrupted():测试当前线程是否已经中断

2)this.isInterrupted():测试线程是否已经中断

测试如下

package com.cky.thread;

/**
 * Created by edison on 2017/11/28.
 */
public class MyThread11 extends  Thread{
    @Override
    public void run() {
        super.run();
        for (int i = 0; i < 50000; i++) {
            System.out.println("i="+i);
        }
    }
}
 1 package com.cky.test;
 2
 3 import com.cky.thread.MyThread11;
 4
 5 /**
 6  * Created by edison on 2017/11/28.
 7  */
 8 public class Test18 {
 9     public static void main(String[] args) {
10         try {
11             MyThread11 th = new MyThread11();
12             th.start();
13             Thread.sleep(2000);
14             th.interrupt();
15             System.out.println("是否停止1="+ th.isInterrupted());
16            System.out.println("是否停止2="+ th.isInterrupted());
17         } catch (InterruptedException e) {
18             e.printStackTrace();
19         }
20     }
21 }
i=49990
i=49991
i=49992
i=49993
i=49994
i=49995
i=49996
i=49997
i=49998
i=49999
是否停止1=false
是否停止2=false

结果分析:

结果表面当前线程并未停止,因为这个当前线程是main线程,所以打印了两个false.

测试

 1 package com.cky.test;
 2
 3 /**
 4  * Created by edison on 2017/11/28.
 5  */
 6 public class Test19 {
 7     public static void main(String[] args) {
 8         Thread.currentThread().interrupt();
 9         System.out.println("是否停止1="+Thread.interrupted());
10         System.out.println("是否停止2="+Thread.interrupted());
11         System.out.println("end");
12
13     }
14 }
1 C:\itsoft\jdk\bin\java -Didea.launcher.port=7534 "-Didea.launcher.bin.path=C:\itsoft\idea\IntelliJ IDEA 2016.3.3\bin" -Dfile.encoding=UTF-8 -classpath "C:\itsoft\jdk\jre\lib\charsets.jar;C:\itsoft\jdk\jre\lib\deploy.jar;C:\itsoft\jdk\jre\lib\ext\access-bridge-32.jar;C:\itsoft\jdk\jre\lib\ext\cldrdata.jar;C:\itsoft\jdk\jre\lib\ext\dnsns.jar;C:\itsoft\jdk\jre\lib\ext\jaccess.jar;C:\itsoft\jdk\jre\lib\ext\jfxrt.jar;C:\itsoft\jdk\jre\lib\ext\localedata.jar;C:\itsoft\jdk\jre\lib\ext\nashorn.jar;C:\itsoft\jdk\jre\lib\ext\sunec.jar;C:\itsoft\jdk\jre\lib\ext\sunjce_provider.jar;C:\itsoft\jdk\jre\lib\ext\sunmscapi.jar;C:\itsoft\jdk\jre\lib\ext\sunpkcs11.jar;C:\itsoft\jdk\jre\lib\ext\zipfs.jar;C:\itsoft\jdk\jre\lib\javaws.jar;C:\itsoft\jdk\jre\lib\jce.jar;C:\itsoft\jdk\jre\lib\jfr.jar;C:\itsoft\jdk\jre\lib\jfxswt.jar;C:\itsoft\jdk\jre\lib\jsse.jar;C:\itsoft\jdk\jre\lib\management-agent.jar;C:\itsoft\jdk\jre\lib\plugin.jar;C:\itsoft\jdk\jre\lib\resources.jar;C:\itsoft\jdk\jre\lib\rt.jar;C:\多线程核心技术\第一章\out\production\第一章;C:\itsoft\idea\IntelliJ IDEA 2016.3.3\lib\idea_rt.jar" com.intellij.rt.execution.application.AppMain com.cky.test.Test19
2 是否停止1=true
3 是否停止2=false
4 end
5
6 Process finished with exit code 0

结果分析:上面结果第一次判断为true,说明当前main线程已经中断,但是第二次调用变成了false.

官方文档解释:线程的中断状态由该方法清除,所以两次调用的话,第二次会返回false.

再来测试isInterrupted()

 1 package com.cky.test;
 2
 3 /**
 4  * Created by edison on 2017/11/28.
 5  */
 6 public class Test19 {
 7     public static void main(String[] args) {
 8         Thread.currentThread().interrupt();
 9         System.out.println("是否停止1="+Thread.currentThread().isInterrupted());
10         System.out.println("是否停止2="+Thread.currentThread().isInterrupted());
11         System.out.println("end");
12
13     }
14 }
C:\itsoft\jdk\bin\java -Didea.launcher.port=7541 "-Didea.launcher.bin.path=C:\itsoft\idea\IntelliJ IDEA 2016.3.3\bin" -Dfile.encoding=UTF-8 -classpath "C:\itsoft\jdk\jre\lib\charsets.jar;C:\itsoft\jdk\jre\lib\deploy.jar;C:\itsoft\jdk\jre\lib\ext\access-bridge-32.jar;C:\itsoft\jdk\jre\lib\ext\cldrdata.jar;C:\itsoft\jdk\jre\lib\ext\dnsns.jar;C:\itsoft\jdk\jre\lib\ext\jaccess.jar;C:\itsoft\jdk\jre\lib\ext\jfxrt.jar;C:\itsoft\jdk\jre\lib\ext\localedata.jar;C:\itsoft\jdk\jre\lib\ext\nashorn.jar;C:\itsoft\jdk\jre\lib\ext\sunec.jar;C:\itsoft\jdk\jre\lib\ext\sunjce_provider.jar;C:\itsoft\jdk\jre\lib\ext\sunmscapi.jar;C:\itsoft\jdk\jre\lib\ext\sunpkcs11.jar;C:\itsoft\jdk\jre\lib\ext\zipfs.jar;C:\itsoft\jdk\jre\lib\javaws.jar;C:\itsoft\jdk\jre\lib\jce.jar;C:\itsoft\jdk\jre\lib\jfr.jar;C:\itsoft\jdk\jre\lib\jfxswt.jar;C:\itsoft\jdk\jre\lib\jsse.jar;C:\itsoft\jdk\jre\lib\management-agent.jar;C:\itsoft\jdk\jre\lib\plugin.jar;C:\itsoft\jdk\jre\lib\resources.jar;C:\itsoft\jdk\jre\lib\rt.jar;C:\多线程核心技术\第一章\out\production\第一章;C:\itsoft\idea\IntelliJ IDEA 2016.3.3\lib\idea_rt.jar" com.intellij.rt.execution.application.AppMain com.cky.test.Test19
是否停止1=true
是否停止2=true
end

Process finished with exit code 0

结果分析:

方法isInterrupted()并未清除状态标识,所以打印了两个false.

时间: 2024-10-09 19:32:19

1.7.2判断线程是否是停止状态的相关文章

C#中如何判断线程当前所处的状态

转自原文 在C#中如何判断线程当前所处的状态 在C#中,线程对象Thread使用ThreadState属性指示线程状态,它是带Flags特性的枚举类型对象. ThreadState 为线程定义了一组所有可能的执行状态.一旦线程被创建,它就至少处于其中一个状态中,直到终止.在公共语言运行时中创建的线程最初处于Unstarted状态中,而进入运行时的外部线程则已经处于Running状态中.通过调用 Start可以将Unstarted线程转换为Running状态.并非所有的ThreadState值的组

判断当前线程所处的状态 (转)以及终止当前线程

在C#中,线程对象Thread使用ThreadState属性指示线程状态,它是带Flags特性的枚举类型对象. ThreadState 为线程定义了一组所有可能的执行状态.一旦线程被创建,它就至少处于其中一个状态中,直到终止.在公共语言运行时中创建的线程最初处于Unstarted状态中,而进入运行时的外部线程则已经处于Running状态中.通过调用 Start可以将Unstarted线程转换为Running状态.并非所有的ThreadState值的组合都是有效的:例如,线程不能同时处于Abort

在C#中如何判断线程当前所处的状态

在C#中如何判断线程当前所处的状态 老帅   在C#中,线程对象Thread使用ThreadState属性指示线程状态,它是带Flags特性的枚举类型对象,因此判断线程当前的状态必须用bitmask按位运算来达到判断目的,不能直接使用相等来判断. 定义ThreadState如下:      1.判断线程是否处于取消状态 A.错误的判断 (MyThread.ThreadState == ThreadState.AbortRequested) B.正确的判断     (MyThread.Thread

Delphi 用TThread如何判断线程是否存在 并且释放线程

判断线程是否存在使用: if Assigned(workThread) then begin //do work end; 释放线程使用: 可以使用线程对象自动释放,使用:workThread.FreeOnTerminate := true; 如果想自己释放线程则应该先判断线程是否存在和是否结束然后再释放,使用 if Assigned(workThread) and (not workThread.Finished) then begin //workThread.terminate; //停止

C#如何判断线程池中所有的线程是否已经完成之Demo

1 start: 2 3 System.Threading.RegisteredWaitHandle rhw = null; 4 new Action(() => 5 { 6 for (var i = 0; i < 30; i++) { 7 new Action<int>((index) => 8 { 9 System.Threading.Thread.Sleep(1000); 10 Console.WriteLine(System.Threading.Thread.Curr

C#如何判断线程池中所有的线程是否已经完成(转)

其 实很简单用ThreadPool.RegisterWaitForSingleObject方法注册一个定时检查线程池的方法,在检查线程的方法内调用 ThreadPool.GetAvailableThreads与ThreadPool.GetMaxThreads并比较两个方法返回的值是不是相等, 相等表示线池内所有的线程已经完成. //每秒检次一次线程池的状态 RegisteredWaitHandle rhw = ThreadPool.RegisterWaitForSingleObject(Auto

Java多线程(4)----线程的四种状态

与人有生老病死一样,线程也同样要经历开始(等待).运行.挂起和停止四种不同的状态.这四种状态都可以通过Thread类中的方法进行控制.下面给出了Thread类中和这四种状态相关的方法. 1 // 开始线程 2 public void start( ); 3 public void run( ); 4 5 // 挂起和唤醒线程 6 public void resume( ); // 不建议使用 7 public void suspend( ); // 不建议使用 8 public static v

java exec检测tomcat服务处于何中状态(正常运行,启动中或停止中, 停止状态)

思想:利用cmd命令进行检查 正常运行:cmd /c net start 会输出已启动的列表,比对是否在列表中 启动中或停止中:cmd /c net start tomcat 会输出启动中或停止中的关系提示 停止状态:上面两种之外,就是停止状态 扩展: 本来是想利用cmd startup.bat启动是tomcat,然后此状态(starting)保存到数据库 利用cmd  startdown.bat关闭是tomcat,然后此状态(stopping)保存到数据库 发现其中启动和关闭还需要时间,无法检

线程的五种状态及改变状态的三种方法

1.新状态:线程对象已经创建,还没有在其上调用start()方法. 2.可运行状态:当线程有资格运行,但调度程序还没有把它选定为运行线程时线程所处的状态.当start()方法调用时,线程首先进入可运行状态.在线程运行之后或者从阻塞.等待或睡眠状态回来后,也返回到可运行状态. 3.运行状态:线程调度程序从可运行池中选择一个线程作为当前线程时线程所处的状态.这也是线程进入运行状态的唯一一种方式. 4.等待/阻塞/睡眠状态:这是线程有资格运行时它所处的状态.实际上这个三状态组合为一种,其共同点是:线程