MultiThread

join()

threadB中调用threadA.join(),表示threadB线程进入等待状态,让线程threadA去执行,待线程threadA完毕后继续执行当前线程。


synchronized关键字

  • 声明代码块 - synchronized(obj):
    当synchronized(obj)中的obj为同一个对象时,代码块同步执行。如:synchronized(xxx.class)、synchronized("")、同一个对象的synchronized(this);而代码块异步执行的例子有:不同对象的synchronized(this)。反之异步执行。
    另外注意:synchronized([同一对象])声明的代码段范围,范围内同步,范围外异步。

  • 声明方法 - synchronized void method(args){}:
    相当于synchronized(this),所以还是要注意是否为同一对象。(注:static方法除外。)


yield()

该方法与sleep()类似,只是不能由用户指定暂停多长时间,并且yield()方法只能让同优先级的线程有执行的机会。


wait()、notify()、notifyAll()

这三个方法用于协调多个线程对共享数据的存取,所以必须在synchronized语句块内使用。synchronized关键字用于保护共享数据,阻止其他线程对共享数据的存取,但是这样程序的流程就很不灵活了,如何才能在当前线程还没退出synchronized数据块时让其他线程也有机会访问共享数据呢?此时就用这三个方法来灵活控制。
  wait()方法使当前线程暂停执行并释放对象锁标示,让其他线程可以进入synchronized数据块,当前线程被放入对象等待池中。
  当调用notify()方法后,将从对象的等待池中移走一个任意的线程并放到锁标志等待池中,只有锁标志等待池中线程能够获取锁标志;如果锁标志等待池中没有线程,则notify()不起作用。
  notifyAll()则从对象等待池中移走所有等待那个对象的线程并放到锁标志等待池中。


ThreadLocal

副本变量,即每个线程独有的变量。

private static ThreadLocal localVar = new ThreadLocal<>() {  
    public T initialValue() {  
        return t;
    }  
};
localVar.get();
localVar.set(t);


volatile

会使工作内存中的变量被修改以后,能够及时刷新至主内存。

  • 作用一:标记状态
  • 作用二:单例模式中的双重判空(避免出现“指令重排序”的情况)

相关文章:

《Java并发编程:volatile关键字解析》

你可能感兴趣的:(MultiThread)