java:juc一
一: 內存可見性(volatile)
? ? ? 內存可見性問題: 當多個線程操作共享數據時,彼此不可見。
? ? ??volatile關鍵字,當多個線程進行操作共享數據時,可以保證內存中的數據可見。 相較于synchronized,?volatile不具有互斥性,并且不能保證原子性。
?
?
/** * volatile關鍵字,當多個線程進行操作共享數據時,可以保證內存中的數據可見。 * */ public class TestVolatile {public static void main(String[] args) {ThreadDemo td = new ThreadDemo();new Thread(td).start();// try { // Thread.sleep(4000); // } catch (InterruptedException e) { // e.printStackTrace(); // }while(true){// 加鎖也能解決可見性,但是效率很低//synchronized (td){if(td.isFlag()){System.out.println("------");break;}//}}} }class ThreadDemo implements Runnable{// 沒有使用volatile關鍵字private boolean flag = false;public boolean isFlag() {return flag;}public void setFlag(boolean flag) {this.flag = flag;}@Overridepublic void run() {try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}flag = true;System.out.println("flag="+flag);} }?
?二: cas算法
? ?cas算法是硬件對于并發操作共享數據的支持。 cas算法包含了三個操作: 1.內存值V? ?2. 預估值A? ?3. 更新值B。? ? 當且僅當V == A時, V = B。
?
?
?
?
?
總結
- 上一篇: springboot:自动配置原理入门
- 下一篇: java:BIO, NIO