午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Java SE 多線程安全問題產生的原因?

瀏覽:174日期:2023-11-05 17:56:07

問題描述

可能像圖片上的代碼出現負數的概率不大,但在if語句后加上Thread.sleep(10);就能看到輸出負數Java SE 多線程安全問題產生的原因?

問題解答

回答1:

不知道你要問什么,多個線程同時讀取一個資源出現不同步問題很正常,因為可能一個線程獲取值的時候另一個線程恰好在寫值,這就會產生同步問題。

解決辦法有很多,最笨的直接代碼塊上加同步,整個鎖起來;好點的是用線程安全的類,比如AtomInteger這種,保證同步;如果對多線程很有研究,甚至可以只加很少的鎖就能完成任務。

回答2:

線程的調用順序是不保證有序的,其根本原因在于JVM協調資源時線程之間的切換。

回答3:

本質原因是CPU為了提高效率會對指令進行重排序

回答4:

沒有對num進行同步,不能保證當前線程對num的值改之后,其他線程可以立馬看到,題主可以了解下Java內存模型。 以題主的代碼為例,假設執行到最后num=1,三個線程同時執行到if判斷,都能判斷出通過,那就有可能出現負數。

回答5:

1、內存可見性2、修改的原子性

由于num是類靜態變量,那么它會被存到堆中,在run()方法執行時拷貝一份副本到棧中存儲,當有多個線程修改時,可能同時拿到一樣的副本,但是由于執行的前后順序,一個線程修改并寫入了該變量,雖然堆中num已經發生變化,但是其他線程并不知道,它們會繼續修改那份副本。然后修改后寫入堆中,那這樣就會覆蓋之前線程的修改,進而導致狀態的不一致問題。那么如果才能確保線程安全性呢。那就要確保修改num之前保證對堆區修改的可見性,修改之前再拿一份副本(即使之前已經拿過了),這個可用volatile關鍵字來保證。

原子性,由于num--實際執行是兩個操作,那么就會存在執行順序問題。即使在前面說過用volatilel來保證可見性。但是還會存在修改被其他線程覆蓋的情形,只不過幾率變小了。怎樣保證原子性呢,可以采用synchronized關鍵字,Lock機制,以及JDK并發工具包等。對于這種情形,最簡單的辦法就是

private static AtomicInteger num=new AtomicInteger(100);

標簽: java
相關文章:
主站蜘蛛池模板: 国产精品嫩草久久久久 | 国产 欧美 在线 | 日本男女啪啪 | 99热国产| 亚洲第一区在线 | 精品福利一区 | 日本黄色免费在线观看 | 午夜精品久久久久久久 | 国产精品成人免费精品自在线观看 | 久久久亚洲天堂 | 国产永久免费观看 | 国产999久久久 | 国产精品久久久久永久免费看 | 欧美激情黑白配 | 日韩精品中文在线 | 亚洲男人天堂视频 | 亚洲色图清纯唯美 | 亚洲一二区视频 | 国产一区精品在线观看 | 一级视频在线 | 国产一区a | 日本特黄特色aaa大片免费 | 亚洲视频在线观看免费 | 日韩视频一区 | 免费av在线播放 | 亚洲精品伊人 | 亚洲精品午夜国产va久久成人 | www视频在线观看 | 亚洲视频免费观看 | 69精品人人 | 蜜臀视频网站 | 免费在线播放av | 九九热视频精品 | 嫩草99 | 成人h片在线观看 | 99色精品 | 久久av一区| 中文av片 | 岛国av网 | 在线观看欧美精品 | 在线播放毛片 |