wait 方法:是 Object 的方法,必须与 synchronized 关键字一起使用,线程进入阻塞状态,当 notify 或者 notifyall 被调用后,会解除阻塞。但是,只有重新占用互斥锁之后才会进入可运行状态。睡眠时,释放互斥锁。
13.5tom_vip_20171225_mongoddb楂樺彲鐢ㄥ疄鎴樻紨缁?琛ュ厖)-.mp4。
[ java鏋舵瀯甯?018鍏ㄥvip璇剧▼ ] 鐢卞垎浜汉 鎴戞槸*7鏃犳倲 浜?2019-01-28 15:32 涓婁紶鍒扮櫨搴︾綉鐩樸€傛椤甸潰鐢辫湗铔涚▼搴忚嚜鍔ㄦ姄鍙栵紝浠ラ潪浜哄伐鏂瑰紡鑷姩鐢熸垚锛屽彧浣滀氦娴佸拰瀛︿範浣跨敤銆傛湰缃戠珯鏈韩涓嶅偍瀛樹换浣曡祫婧愭枃浠讹紝鍏惰祫婧愭枃浠剁殑瀹夊叏鎬у拰瀹屾暣鎬ч渶瑕佹偍鑷鍒ゆ柇锛屾劅璋㈡偍瀵规湰绔欑殑鏀寔銆?。
如果要挂起或者唤醒一个线程,都需要操作系统帮忙完成,而操作系统实现线程之间的切换时需要从用户态转换到内核态,这个状态之间的转换需要相对比较长的时间,时间成本相对较高,这也是为什么早期的synchronized效率低的原因。
另外,在Java早期版本中,synchronized属于重量级锁,效率低下,因为监视器锁(monitor)是依赖于底层的操作系统的MutexLock来实现的,Java的线程是映射到操作系统的原生线程之上的。
此外,必须注意,只有同一实例的synchronized方法同一时间只能被一个线程执行,不同实例的synchronized方法是可以并发的。例如,class A定义了synchronized方法sync,则不同实例a1.sync和a2.sync可以同时由两个线程来执行。