volatile關(guān)鍵字的作用 C# volatile是否能保證原子性?
C# volatile是否能保證原子性?Volatile不能保證原子性。它只保證每次都能訪問真實的數(shù)據(jù)。編譯器不會優(yōu)化它。它需要實現(xiàn)原子性,或者鎖定,或者使用與平臺相關(guān)的匯編代碼。java里volat
C# volatile是否能保證原子性?
Volatile不能保證原子性。它只保證每次都能訪問真實的數(shù)據(jù)。編譯器不會優(yōu)化它。它需要實現(xiàn)原子性,或者鎖定,或者使用與平臺相關(guān)的匯編代碼。
java里volatile關(guān)鍵字有什么特性是否能保證線程安全?
1. Volatile不能保證原子性。簡而言之,Java有所謂的主存區(qū)和線程棧。在主內(nèi)存區(qū)域和每個線程的堆棧中都有相同變量的副本(一對多)。volatile提供的可見性意味著當(dāng)每個線程訪問volatile修改的變量時,volatile確保線程可以從主存加載最新的值(相反,修改線程后同步到主存的值也應(yīng)該對其他線程可見);
2。Java的volatile的語義實際上并不涉及CPU緩存。JVM本身是一個軟件抽象,它已經(jīng)在操作系統(tǒng)之上了。由于非原子性,volatile不能保證線程安全。如果只有簡單的讀寫操作,比如set I=2,get I,就可以認(rèn)為是安全的。4Volatile被認(rèn)為比lock更輕,編程更簡單。可以使用volatile的地方:對于一個變量,更新它的值不依賴于當(dāng)前值,并且該變量不會與其他變量形成一個不可變的條件。
volatile能使得一個非原子操作變成原子操作嗎?
JAVA內(nèi)存模型是為了解決多線程環(huán)境下共享變量的一致性問題。一致性主要包括三個特征:原子性、可見性和有序性。原子性
一個程序在開始時不會被其他線程中斷。它可以是一個操作或多個操作。操作原子性由synchronized和lock關(guān)鍵字保證;
2當(dāng)一個線程更改共享變量的值時,其他線程可以立即檢測到更改;volatile variable確保變量在多線程環(huán)境中的可見性,但不能保證原子操作;
除了volatile,還有兩個關(guān)鍵字可以保證可見性,分別是synchronized和final;
所以你可以看到synchronized,也就是說你可以保證Java程序中的原值,如果在這個線程中觀察到,所有操作都是有序的;如果在另一個線程中觀察到,所有操作都是無序的。前半句是指線程中序列化的語義,后半句是指主存和工作內(nèi)存之間的指令重排序和同步延遲問題;
Java提供了兩個關(guān)鍵字:volatile和synchronized來保證順序。
多個線程可以讀一個變量,只有一個線程可以對這個變量進(jìn)行寫,到底要不要加鎖?
下面簡要說明以下原因:
鎖定是因為操作不是原子的。讓我們用操作一來解釋它??聪旅鎯蓚€圖。
我這個操作需要
看上面的第二個圖,你能很清楚地理解這個過程嗎?
鎖定是為了確保上述三個步驟是原子操作。
回到問題上來,只有一個線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因為主內(nèi)存和本地內(nèi)存的存在
在一個線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關(guān)鍵字后,它將在操作后強(qiáng)制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。