拆解Java并发编程!(1-2)

47 阅读3分钟
  1. 线程优先级 线程优先级会提示任务调度器优先调度该线程,但仅仅是一个提示,具体做法还是得看任务调度器CPU忙时,优先级高的线程得到更多的时间片,CPU空闲时,优先级几乎没用
  2. 案例-防止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("结束");
    }
}
  1. interrupt interrupt:

打断处于阻塞状态的线程(调用了sleep,wait,join方法的线程)时,会清空打断标记(false) 打断处于运行状态的线程时,不会清空打断标记(true),不会强制终止线程,然后线程可以根据打断标记来决定是否继续运行(Thread.currentThread().isInterrupt()) isInterrupt:

获取打断标记(true/false) 5. LockSupport.park() 打断park线程时不会清空打断状态,如果打断标记已经是true,则park不会生效 6. 不推荐的方法

  1. 主线程与守护线程 默认情况,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状态

————————————————