介绍线程类常用方法
-
start方法: 让一个线程进入就绪状态
-
run方法:线程真正要执行的逻辑,让一个线程分配的cpu资源,开始启动就会调用run方法执行
-
sleep(n)方法:让线程休眠n毫秒,休眠时会让出cpu但不会释放锁。
-
join方法:当前线程等待目标线程运行结束,再开始运行。可以设置超时时间
-
interrupt()方法:打断线程,如果打断正在sleep,wait,join的方法会抛出InterruptedException异常,并清除打断标记。
如果打断正在执行的线程,会设置打断标记但不会真的打断它,如果打断正在park的线程会真的打断park状态,而且设置打断标记。 -
yield()方法:让当前线程从执行态变为就绪态。
-
setDaemon(true)方法:设置一个线程为守护线程。
-
setPriority(int)方法:修改线程的优先级。
-
stop()方法:强制杀死当前线程,已经过时
获取线程对象相关属性
- getState()方法:获取线程状态,NEW RUNNABLE BLOCKED WAITING TIMED_WAITING
- currentThread()方法:获取正在执行当前方法的线程对象。
- isAlive()方法:判断线程是否存活(还没有运行完毕)
- getId方法:获取线程的唯一id。
- getName方法:获取线程的名称
- getPriority()方法:获取线程优先级。
- isInterrupted()方法:获取线程是否被打断的标志,不会重置,默认一个线程创建后打断标记为false。
- interrupted()方法:获取线程是否被打断的标志并清除标记(重新置为false)
start和run方法区别
- 通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪状态,并没有运行,一旦得到cpu时间片,就开始执行run()方法,此时线程变为执行态,run方法运行结束,此线程随即终止。
- 所以start方法只是启动一个线程,使得一个线程处于就绪状态,只有调用run方法线程才会真正执行。但是run方法不能由用户手动调用,否则还是主线程在执行。
Thread t = new Thread(){
@Override
public void run() {
}
};
log.info(t.getState().toString()); //start之前子线程状态 NEW
t.start();
log.info(t.getState().toString());//start之后子线程状态 RUNNABLE
sleep方法
- 在一个线程中调用sleep方法,会让当前线程休眠,线程会由运行状态变为有时限等待状态。
- 子线程休眠结束后会变为就绪状态,然后等待cpu空闲再调度执行。
- 调用sleep方法,即使线程休眠了,线程也不会释放锁但是会释放cpu。
Thread.sleep(1000);
- sleep方法可以避免cpu占用百分百,如下如果不加休眠cpu占用很高,加了之后可以避免这种情况
while (true){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace(); }
//完成定时任务逻辑
}
yield方法
- yield方法被调用后,会让当前线程从执行态变为就绪态,然后调度执行其他就绪状态的线程。
- yield方法不一定能保证当前线程暂停的效果,因为一个线程调用yield方法后变为就绪态,此时没有其他的线程需要cpu,那么调度器会再次把cpu交给当前线程。
- 示例 创建两个线程执行打印操作,在线程2中打印前调用yield方法将自己变为就绪状态。 可以发现线程a的打印速度明显快于线程b的打印速度。
Thread t1 = new