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