第1章:并发编程线程基础

    一个线程获取一个共享变量的监视器锁的方法

    • 执行synchronized同步代码块时,使用该共享变量作为参数:
    • 调用该共享变量的方法,并且该方法使用了synchronized修饰:
      1. //do something
      2. }

    虚假唤醒在实践中很少发生,但要防患于未然,如下:

    notify()和notifyAll()

    notify()会唤醒被阻塞到该共享变量上的一个线程,notifyAll()会唤醒所有在该共享变量上由于调用wait系列方法而被挂起的线程。

    1. ...
    2. ...
    3. thread1.join();
    4. thread2.join();
    5. }

    主线程首先会在调用thread1.join()后被阻塞,等待thread1执行完毕后,thread2开始阻塞,以此类推,最终会等所有子线程都结束后main函数才会返回。

    sleep()

    线程调用yield()方法时,实际上是暗示线程调度器当前线程请求让出自己的CPU使用(告诉线程调度器可以进行下一轮的线程调度),但线程调度器可以无条件忽略这个暗示。

    线程中断

    设置线程的中断标志为true并立即返回,但线程实际上并没有被中断而会继续向下执行;如果线程因为调用了wait系列函数、join方法或者sleep方法而被阻塞挂起,其他线程调用该线程的interrupt()方法会使该线程抛出InterruptedException异常而返回。

    检测当前线程是否被中断,是则返回true,否则返回false。

    检测当前线程是否被中断,返回值同上,但如果发现当前线程被中断,会清除中断标志;该方法是static方法,内部是获取当前调用线程的中断标志而不是调用interrupted()方法的实例对象的中断标志。

    输出为

    1. isInterrupted:true
    2. isInterrupted:false
    3. isInterrupted:true

    当最后一个用户进程结束时,JVM会正常退出,而不管当前是否有守护进程。

    运行后发现虽然输出了”main is over”,但ide运行状态红框仍亮着,说明JVM进程未结束,如图:

    打开注释后程序则快速退出。

    更多

    相关笔记: