1.线程id可以通过Thread对象的getId()方法得到,在线程出了问题,为什么CPU占用这么高的时候,查的时候我们可以在堆栈信息中找到对应线程,然后干掉该线程就好!
2.而线程对象的getName方法可以获得该线程的线程名,线程名默认是Thread-数字,当然我们也可以自己指定线程名!
public final String getName() {
return String.valueOf(name);
}
3.可以通过线程对象的getPriority方法获取当前该线程的优先级,如下所示:
public final int getPriority() {
return priority;
}
4.可以通过getState方法获取当前对象的状态信息
public State getState() {
// get current thread state
return sun.misc.VM.toThreadState(threadStatus);
}
如下代码演示上述四个方法:
package com.bawei.multithread; public class ThreadSimpleApi {
public static void main(String[] args) {
Runnable run =new Runnable(){
@Override
public void run() {
System.out.println("这是线程1!");
try {
Thread.sleep(100000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
};
Thread t = new Thread(run,"号啊");
t.start();
System.out.println("ThreadName: "+t.getName()+" ThreadId:"+t.getId()+
" ThreadPriority:"+t.getPriority()+"ThreadState:"+t.getState());
}
}
注意:进程也是有优先级的,从我们如下的任务管理器界面中我们可以看到优先级问题,有的进程优先级高,有的进程优先级低,有些软件我们用360的东西杀它但是就是干不掉,就是因为它的优先级比较高!
Java线程:线程的调度-优先级
与线程休眠类似,线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行。
线程的优先级用1-10之间的整数表示,数值越大优先级越高,默认的优先级为5。
在一个线程中开启另外一个新线程,则新开线程称为该线程的子线程,子线程初始优先级与父线程相同。
package com.bawei.multithread; class ThreadSimpleApi {
public static void main(String[] args) {
Thread t1 = new MyThread1();
Thread t2 = new Thread(new MyRunnable());
t1.setPriority(10);
t2.setPriority(1); t2.start();
t1.start();
}
} class MyThread1 extends Thread {
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("线程1第" + i + "次执行!");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
} class MyRunnable implements Runnable {
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("线程2第" + i + "次执行!");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}