摘要:前言面試,必然要被問內存模型和并發開發。但是線程池啟動多線程,是并發執行的。線程線程同時對值為的變量進行操作,結果返回,而不是。要不簡單點,記住多線程對全局變量的寫操作會發生沖突。
前言
面試Java,必然要被問Java內存模型和Java并發開發。我被問到的時候,心里慌得一批,“額,是在《Thinking in Java》里面寫的嗎?果然每天增刪改太low了”
要了解這些圖嗎? 我希望能解釋的再簡單一些,以上都不用public class Example1 { public static int count = 0; public static int clientTotal = 5000; public static void main(String[] args) throws Exception { ExecutorService executorService = Executors.newCachedThreadPool(); for (int i = 0; i < clientTotal ; i++) { executorService.execute(() -> { try { add(); } catch (Exception e) { log.error("exception", e); } }); } } private static void add() { count++; } }
如果上面代碼執行,count的值是多少?(為了說明重點問題,沒有寫最后打印的代碼)
5000?多次運行的結果,count的值是小于5000的。
解釋一下上面的程序,首先定義了一個線程池,啟動5000個線程執行add()操作,add函數處理靜態成員變量count。
如果程序順序調用,count的值應該是5000。
for(int i=0;i<5000;i++){ add(); }
但是線程池啟動多線程,是并發執行的。每個線程啟動之后,不管是否運行結束,下一個線程會馬上啟動。
當多個線程對同一個變量add進行操作的時候,就會發生寫寫沖突。
線程1、線程2 同時對值為0的變量進行操作,結果返回1,而不是2。如果這個地方想不明白,就請留言,或者看看文章頂部那些原理圖。
public class CountExample2 { // 請求總數 public static int clientTotal = 5000; // 同時并發執行的線程數 public static int threadTotal = 200; public static AtomicInteger count = new AtomicInteger(0); public static void main(String[] args) throws Exception { ExecutorService executorService = Executors.newCachedThreadPool(); final Semaphore semaphore = new Semaphore(threadTotal); final CountDownLatch countDownLatch = new CountDownLatch(clientTotal); for (int i = 0; i < clientTotal ; i++) { executorService.execute(() -> { try { semaphore.acquire(); add(); semaphore.release(); } catch (Exception e) { log.error("exception", e); } countDownLatch.countDown(); }); } countDownLatch.await(); executorService.shutdown(); log.info("count:{}", count.get()); } private static void add() { count.incrementAndGet(); // count.getAndIncrement(); } }
注,上面的代碼用了生成者消費者模式,5000個生產者,200個消費者,對程序并發做一定限制,防止5000個線程卡死計算機。
內存模型,也說點簡單的棧(heap),函數加載的時候,為函數內部變量分配的空間。和父函數的內部變量和運行指針共享同一塊區域。
函數運行時,new的空間,都是放在堆中的。
這個就是C的內存模型,做shellcode的基礎知識。
作者:白頭雁
鏈接:https://www.jianshu.com/p/8cb...
終于,我還是碼造一個了中國地圖
SVG前戲—讓你的View多姿多彩
分享幾個Android很強勢的的開源框架
(Android)面試題級答案(精選版)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/108131.html
摘要:前言面試,必然要被問內存模型和并發開發。但是線程池啟動多線程,是并發執行的。線程線程同時對值為的變量進行操作,結果返回,而不是。要不簡單點,記住多線程對全局變量的寫操作會發生沖突。 前言 面試Java,必然要被問Java內存模型和Java并發開發。我被問到的時候,心里慌得一批,額,是在《Thinking in Java》里面寫的嗎?果然每天增刪改太low了 要了解這些圖嗎? showI...
摘要:今天是年月號,一年一度的情人節又來了,今天對于很多年輕人來說是個特別的日子。該程序員在聯誼會上認識了某藝術系女生,同鄉的雙方互有好感。 今天是2018年8月17號,一年一度的情人節又來了,今天對于很多年輕人來說是個特別的日子。但是作為屌絲界的一枚程序員,往往給人的印象是宅,不愛說話,智商不好,也不討好哄女孩子歡心。但是,為什么我身邊的程序員各個都是高智商,高顏值的小碼農呢?或許,他們用...
摘要:使用場景自定義權限一般用于暴露出去的組件,提高安全性。擁有相同自定義權限的軟件必須使用同樣的簽名,否則后一個程序無法安裝。 最近在研究關于android自定義權限的問題,關于自定義權限一般是保證APP的安全性,那么什么事自定義權限?今天我們來補充一下自己的知識 作者:BrightVan地址:https://www.jianshu.com/p/b60... 1、如何聲明自定義權限 在M...
閱讀 2108·2021-11-18 10:02
閱讀 2861·2021-09-04 16:41
閱讀 1153·2019-08-30 15:55
閱讀 1416·2019-08-29 17:27
閱讀 1094·2019-08-29 17:12
閱讀 2538·2019-08-29 15:38
閱讀 2862·2019-08-29 13:02
閱讀 2838·2019-08-29 12:29