volatile關(guān)鍵字相信了解Java多線程的讀者都很清楚它的作用。volatile關(guān)鍵字用于聲明簡(jiǎn)單類型變量,如int、float、boolean等數(shù)據(jù)類型。如果這些簡(jiǎn)單數(shù)據(jù)類型聲明為volatile,對(duì)它們的操作就會(huì)變成原子級(jí)別的。但這有一定的限制。
例如,下面的例子中的n就不是原子級(jí)別的package mythread;
2.
3.public class JoinThread extends Thread
4.{
5. public static volatile int n = 0;
6. public void run()
7. {
8. for (int i = 0; i < 10; i++)
9. try
10. {
11. n = n + 1;
12. sleep(3); // 為了使運(yùn)行結(jié)果更隨機(jī),延遲3毫秒
13.
14. }
15. catch (Exception e)
16. {
17. }
18. }
19.
20. public static void main(String[] args) throws Exception
21. {
22.
23. Thread threads[] = new Thread[100];
24. for (int i = 0; i < threads.length; i++)
25. // 建立100個(gè)線程
26. threads[i] = new JoinThread();
27. for (int i = 0; i < threads.length; i++)
28. // 運(yùn)行剛才建立的100個(gè)線程
29. threads[i].start();
30. for (int i = 0; i < threads.length; i++)
31. // 100個(gè)線程都執(zhí)行完后繼續(xù)
32. threads[i].join();
33. System.out.println("n=" + JoinThread.n);
34. }
35.}
36.
如果對(duì)n的操作是原子級(jí)別的,最后輸出的結(jié)果應(yīng)該為n=1000,而在執(zhí)行上面積代碼時(shí),很多時(shí)侯輸出的n都小于1000,這說(shuō)明n=n+1不是原子級(jí)別的操作。原因是聲明為volatile的簡(jiǎn)單變量如果當(dāng)前值由該變量以前的值相關(guān),那么volatile關(guān)鍵字不起作用,也就是說(shuō)如下的表達(dá)式都不是原子操作。
n = n + 1;
n++;
如果要想使這種情況變成原子操作,需要使用synchronized關(guān)鍵字,如上的代碼可以改成如下的形式
相關(guān)推薦:
2012年下半年計(jì)算機(jī)等級(jí)考試報(bào)名時(shí)間及入口匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |