下午对线程之间通信有了新的理解:
这里只讨论synchronized 修饰 方法的情况,当然也分为两种情况:
1.修饰普通方法
2.修饰静态方法
下面先讨论修饰普通方法的情况,当synchronized修饰方法的时候,这个对象会被上锁,就是说,不光是当前被synchronized修饰的方法不能被其他线程锁访问,这个对象的其他被synchronized修饰的方法也不能被其他线程访问(经测试,非synchronized可以被其他线程访问),好,那么现在,什么情况下,这个锁会被释放呢,我目前经过测试有以下情况:
1.当前方法执行完毕或出现异常;
2.当前方法调用wait()方法
那么什么情况下用notify(notifyAll)方法呢,当有一个线程调用wait()方法等待唤醒时,如果不调用notify,调用wait()方法的线程将一直处于等待状态,jvm也将不会终止,所以wait 是和 notify 配套使用的,当调用wait(),必须调用nofify()或notifyAll方法唤醒。
线程获得锁的三种方式:
1.通过执行synchronized方法
2.执行synchronized代码块
3.执行静态synchronized方法,这是属于类级别,不是对象级别的了
notify和notifyAll的区别:
notify只唤醒一个等待的线程,而notifyAll则唤醒所有等待的线程,这些线程再竞争锁,也就是说,notify的竞争阶段发生在唤醒,只要唤醒了,就有获得锁的机会,而notifyAll竞争发生在获取锁的阶段