- 线程优先级 线程优先级会提示任务调度器优先调度该线程,但仅仅是一个提示,具体做法还是得看任务调度器CPU忙时,优先级高的线程得到更多的时间片,CPU空闲时,优先级几乎没用
- 案例-防止CPU占用100% 在没有利用CPU来计算时,不要让while(true)死循环空转浪费CPU,这时可以使用yield或sleep或wait,让出CPU的使用权给其他程序
sleep方法适用于无需同步锁的场景
public class ThreadSleepMethod {
public static void main(String[] args) throws InterruptedException {
while (true) {
Thread.sleep(50);
}
}
}
- wait和yield方法都需要加锁,并需要唤醒操作,适用于需要进行同步的场景
3.join
join:
- 等待调用此方法的线程运行结束,适用于需要同步的场景
- 参数long类型:指定等待最大时间
```@Slf4j
public class ThreadJoinMethod {
public static int result = 0;
public static void main(String[] args) throws InterruptedException {
method();
}
public static void method() throws InterruptedException {
log.debug("开始");
Thread t1 = new Thread(()->{
log.debug("开始");
try {
Thread.sleep(1000);
result = 10;
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
},"t1");
t1.start();
t1.join();
log.debug("结果为:{}",result);
log.debug("结束");
}
}
- interrupt interrupt:
打断处于阻塞状态的线程(调用了sleep,wait,join方法的线程)时,会清空打断标记(false) 打断处于运行状态的线程时,不会清空打断标记(true),不会强制终止线程,然后线程可以根据打断标记来决定是否继续运行(Thread.currentThread().isInterrupt()) isInterrupt:
获取打断标记(true/false) 5. LockSupport.park() 打断park线程时不会清空打断状态,如果打断标记已经是true,则park不会生效 6. 不推荐的方法
- 主线程与守护线程 默认情况,Java进程会等待所有线程运行结束之后才会结束.
守护线程是只要其他非守护线程运行结束了,即时守护线程的代码没有执行完毕,也会强制结束守护线程.
守护线程通过线程调用setDaemon来设置当前线程是否为守护线程 守护线程应用于垃圾回收器线程,Tomcat中的Acceptor,Poller线程 当所有线程都停止了,垃圾回收线程会强制结束 当Tomcat接收到shutdown命令后,不会等待Acceptor,Poller线程处理完当前请求,而是直接结束 8. 线程状态 8.1 五种状态-操作系统
初始状态:仅仅在语言层面上创建了线程对象,还没有与操作系统关联
可运行状态:线程对象已经与操作系统关联,可以运行,但还未获得CPU时间片
运行状态:线程对象已经获得CPU时间片并正在运行,当时间片用完时,进行线程上下文切换,变为可运行状态
阻塞状态:运行状态调用阻塞API就会进行线程上下文切换进入阻塞状态,这时CPU不会分发时间片给阻塞状态中的线程
例如线程进行BIO读写文件时就会进入阻塞状态,等待BIO结束后,由操作系统唤醒阻塞中的线程,转变为可运行状态
阻塞状态中的线程一直不被唤醒,CPU就不会考虑分发时间片
终止状态:表示当前线程生命周期已经结束,不会转变为其他状态了
8.2 六种状态-JavaAPI
new:线程创建但还未调用start方法时,是new状态
runnable:线程创建后调用start方法时,是runnable状态
blocked:线程获取对象锁,但此对象锁已被其他对象获取且并未释放时,是blocked状态
waiting:线程调用没有时限等待方法(join,sleep等)时,是time状态
time_waiting:线程调用指定时限的休眠方法(sleep,wait等)时,是time_waiting状态
terminated:线程代码运行结束时,是terminated状态
————————————————