多线程
synchronized锁
java中的每个对象都有一个锁(lock)或者叫做监视器(monitor),当访问某个对象的synchronized的方法时,表示对该对象上锁,此时其他任何线程都无法再去访问该synchronized方法了,直到之前的那个线程执行方法完毕后(或者是抛出异常),那么将该对象的锁释放掉,其他线程才有可能再去访问该synchronized方法。
如果一个对象有多个synchronized方法,某一时刻某个线程已经进入到了某个synchronized方法,那么在该方法没有执行完毕前,其他线程是无法访问该对象的任何synchronized方法的。
如果某个synchronized方法时static 的,那么当前线程访问该方法时,它锁的并不是synchronized方法所在的对象,而是synchronized方法所在对象对应的类,因为java无论一个类中有多少个对象,这些对象会对应唯一一个class对象,因此线程分别访问同一个类的两个对象的两个static,synchronized方法时,他们的执行顺序也是顺序的,也就说一个县城先去执行方法,执行完毕后另一个线程才开始执行。
synchronized块,写法:
synchronized(object){
}
表示线程在执行的时候会对object对象上锁
synchronized方法是一种粗粒度的并发控制,某一时刻,只能有一个线程执行该synchronized方法;synchronized块则是一种细粒度的并发控制,只能将块中的代码同步,位于方法内、synchronized块以外的代码是可以被多个线程同时访问到的。
wait() notify()
都是定义在object类中的,而且是final的,因此才会被所有的java类继承并且无法重写。这两个方法要求在调用时线程已经获得了对象的锁,因此对这两个方法的调用需要放在synchronized方法或者是块中。当线程执行了wait方法时,它会释放掉对象的锁。
另一个会导致线程暂停的方法是Thread 类的sleep方法,它会导致线程睡眠指定毫秒数,但是线程在睡眠的过程中是不会释放掉对象的锁的。