线程管理之获取和设置线程信息

获取和设置线程信息

Thread类的对象中保存了一些属性信息能够帮助我们来辨别每一个线程,知道它的状态,调整控制其优先级。 这些属性是:

  • ID: 每个线程的独特标识。
  • Name: 线程的名称。
  • Priority: 线程对象的优先级。优先级别在1-10之间,1是最低级,10是最高级。不建议改变它们的优先级,但是你想的话也是可以的。
  • Status: 线程的状态。在Java中,线程只能有这6种中的一种状态: new, runnable, blocked, waiting, time waiting, 或 terminated. 准备 指南中的例子是使用Eclipse IDE 来实现的。如果你使用Eclipse 或者其他的IDE,例如NetBeans, 打开并创建一个新的java项目。 怎么做呢 按照这些步骤来实现下面的例子:
  • 1.   创建一个类名为 Calculator,这个类一定要实现Runnable接口。
1 public class Calculator implements Runnable {    
  • 2.   声明一个名为number的private int为属性,然后实现类的构造函数并初始化其值。
1 private int number;       
2 public Calculator(int number) {       
3  this.number=number;       
4 }    
  • 3.   实现方法run()。此方法是给我们创建的线程执行下达指令的,所以这个方法将计算并且打印数字乘法表。
1 @Override       
2 public void run() {       
3 for (int i=1; i<=10; i++){       
4  System.out.printf("%s: %d * %d = %d\n",Thread. currentThread().getName(),number,i,i*number);       
5 }       
6 }    
  • 4.   现在, 实现应用的主类。创建一个名为Main的类,并包含 main() 方法.
1 public class Main {       
2 public static void main(String[] args) {    
  • 5.  创建一个线程Thread,输出线程执行start()方法之前,线程的相关属性信息:线程ID、线程名称、线程状态、线程运行级别。
Thread thread1=new Thread(new Calculator(1));  
        //获取线程ID  
        long id=thread1.getId();  
        //获取线程名称  
        String name=thread1.getName();  
        //获取线程级别  
        int  priority =thread1.getPriority();  
        //获取线程状态  
        Thread.State state=thread1.getState();  
        System.out.println("id is:"+id);  
        System.out.println("name is:"+name);  
        System.out.println("priority is:"+priority);  
        System.out.println("state is:"+state);  

6.    在启动新建Thread 线程之前,首先修改一下,线程的相关配置信息:线程名称和线程运行级别并启动线程。

System.out.println("----------重新设置Thread的相关属性,并启动线程--------------");  
        thread1.setName("thread-----111");  
        thread1.setPriority(Thread.MAX_PRIORITY);  
        thread1.start();  

7、新建线程Thread启动后,立即打印Thread线程的相关属性信息

System.out.println("----------重新获取Thread的相关数据信息--------------");  
    System.out.println("id is:"+thread1.getId());  
    System.out.println("name is:"+thread1.getName());  
    System.out.println("priority is:"+thread1.getPriority());  
    System.out.println("state is:"+thread1.getState());  

8、在main方法中,通过休眠主线程查看Thread.state的状态变化。

try {  
            Thread.sleep(5000);  
            System.out.println("----------Thread.state的状态信息--------------");  
            System.out.println("state is:"+thread1.getState());  
        } catch (InterruptedException e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  

更多 在这个指南中,你学习了如何使用Thread对象来访问线程的属性信息。你也可以实现Runnable接口来访问这些信息。你可以用Thread类的静态方法currentThread()来访问正在运行的Runnable 对象的 Thread对象。 你必须知道 setPriority() 方法会抛出 IllegalArgumentException 异常,如果你设置的优先级不是在1-10之间。

  • Thread 类有能保存使用线程信息的属性。JVM根据线程的优先级来选择将使用CPU的线程,然后再根据每个线程的情况来实现它们的状态。 如果你没有声明一个线程的名字,那么JVM会自动命名它为:Thread-XX,XX是一个数字。线程的ID或者状态是不可修改的。Thread类没有实现setId()和setStatus()方法来允许修改它们。
  • 源代码:
package com.java.demo;  
 
public class Calculator implements Runnable {  
    private int number;  
 
    public Calculator(int number) {  
        this.number = number;  
    }  
 
 @Override 
    public void run() {  
        for (int i = 1; i <= 10; i++) {  
            System.out.printf("%s: %d * %d = %d\n", Thread.currentThread().getName(), number, i, i * number);  
 
        }  
 
    }  
 
}  

package com.java.demo;   
 
public class Main {  
    public static void main(String[] args) {  
        Thread thread1=new Thread(new Calculator(1));  
        //获取线程ID  
        long id=thread1.getId();  
        //获取线程名称  
        String name=thread1.getName();  
        //获取线程级别  
        int  priority =thread1.getPriority();  
        //获取线程状态  
        Thread.State state=thread1.getState();  
        System.out.println("id is:"+id);  
        System.out.println("name is:"+name);  
        System.out.println("priority is:"+priority);  
        System.out.println("state is:"+state);  
 
        System.out.println("----------重新设置Thread的相关属性,并启动线程--------------");  
        thread1.setName("thread-----111");  
        thread1.setPriority(Thread.MAX_PRIORITY);  
        thread1.start();  
        System.out.println("----------重新获取Thread的相关数据信息--------------");  
        System.out.println("id is:"+thread1.getId());  
        System.out.println("name is:"+thread1.getName());  
        System.out.println("priority is:"+thread1.getPriority());  
        System.out.println("state is:"+thread1.getState());  
 
 
        try {  
            Thread.sleep(5000);  
            System.out.println("----------Thread.state的状态信息--------------");  
            System.out.println("state is:"+thread1.getState());  
        } catch (InterruptedException e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
 
    }  
 
}  

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏向治洪

java 的序列化和反序列化的问题

引言 将 Java 对象序列化为二进制文件的 Java 序列化技术是 Java 系列技术中一个较为重要的技术点,在大部分情况下,开发人员只需要了解被序列化的...

19510
来自专栏Java帮帮-微信公众号-技术文章全总结

Java面试系列8

? 一、heap和stack有什么区别 栈是一种线形集合,其添加和删除元素的操作应在同一段完成。 栈按照后进先出的方式进行处理。 堆是栈的一个组成元素 ...

3065
来自专栏Android相关

X86 Assemble指令--MOVS指令簇

该指令簇包括: MOVS mem16,mem16:显式指定源操作数与目的操作数 MOVSB:每次移动一个字节 MOVSW:每次移动一个字 MOVSD:每...

1282
来自专栏desperate633

共享资源的线程安全性Local VariablesLocal Object ReferencesObject Member VariablesThe Thread Control Escape Rul

如果某段代码可以正确的被多线程并发的执行,那么我们就称这段代码是线程安全的,如果一段代码是线程安全的那么他肯定不会出现资源竞速的问题。资源竞速的问题只发生在多个...

561
来自专栏大内老A

关于CLR内存管理一些深层次的讨论[上篇]

半年之前,PM让我在部门内部进行一次关于“内存泄露”的专题分享,我为此准备了一份PPT。今天无意中将其翻出来,觉得里面提到的关于CLR下关于内存管理部分的内存还...

1898
来自专栏Python小屋

学习Python的利器:内置函数dir()和help()

(1)内置函数dir()用来查看对象的成员。在Python中所有的一切都是对象,除了整数、实数、复数、字符串、列表、元组、字典、集合等等,还有range对象、e...

3408
来自专栏haifeiWu与他朋友们的专栏

Java命令之javap初探

javap是jdk自带的一个工具在jdk安装目录的/bin下面可以找到,可以对代码反编译,也可以查看java编译器生成的字节码,对代码的执行过程进行分析,了解j...

922
来自专栏自动化测试实战

RF自定义系统关键字

3757
来自专栏崔庆才的专栏

Python 3 中 PyMongo 的用法

MongoDB存储在这里我们来看一下Python3下MongoDB的存储操作,在本节开始之前请确保你已经安装好了MongoDB并启动了其服务,另外安装好了Pyt...

2.7K1
来自专栏Python小屋

Python处理文本文件案例一则

问题描述:当前文件夹中有一文件data.txt,其中包含一些自然数,每行一个。要求编写程序,读取data.txt中的所有自然数,将其升序排序之后写入新文件dat...

1163

扫码关注云+社区