Java多线程之LockSupport基础篇

390 阅读1分钟

一、LockSupport有什么用

  • LockSupport.park()方法能阻塞线程,LockSupport.unpark()方法能唤醒线程

二、LockSupport与wait()和notify() 有什么区别

  • wait()需释放锁,因此必须结合synchronized使用(没有加锁锁时使用会抛出IllegalMonitorStateException,反例代码如下),notify()也要在synchronized使用,并且应该指定对象,synchronized(),wait(),notify() 操作的对象必须一致,一个synchronized()代码块中只能有1个线程wait()或notify()
public class MyThread {
    public static void main(String[] args) {
        new Thread(() -> {
            for (int i = 0; i < 100; i++) {
                try {
                    Thread.sleep(1000);
                    System.out.println(Thread.currentThread().getName() + ":" + i);
                    if (i == 5) {
                        Thread.currentThread().wait();
                    }
                    if (i == 6) {
                        Thread.currentThread().notify();
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }

        }, "线程1").start();
        
    }
}

运行结果

  • LockSupport.park()LockSupport.unpark()可以结合synchronized使用,也完全可以不结合synchronized使用

LockSupport示例代码注意看注释

public class MyLockSupport {

    public static void main(String[] args) throws InterruptedException {
        Thread thread1 = new Thread(() -> {
            for (int i = 0; i < 100; i++) {
                System.out.println(i);
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                if (i == 5) {
                    synchronized (MyLockSupport.class){
                    // i==5 的时时候阻塞”线程1“
                    LockSupport.park();
                    System.out.println(Thread.currentThread().getState());}
                }
            }

        },"线程1");
        thread1.start();
        /*唤醒指定的线程,注意此方法不一定比LockSupport.park()方法后执行,
         *一旦线程被执行了LockSupport.unpark(thread1)方法,此线程将不会被park了
         * */
        LockSupport.unpark(thread1);
        System.out.println(thread1.getState());
    }
}