国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Java并發(fā)面試,幸虧有點道行,不然又被忽悠了

DevTTL / 2482人閱讀

摘要:前言面試,必然要被問內(nèi)存模型和并發(fā)開發(fā)。但是線程池啟動多線程,是并發(fā)執(zhí)行的。線程線程同時對值為的變量進行操作,結(jié)果返回,而不是。要不簡單點,記住多線程對全局變量的寫操作會發(fā)生沖突。

前言

面試Java,必然要被問Java內(nèi)存模型和Java并發(fā)開發(fā)。我被問到的時候,心里慌得一批,“額,是在《Thinking in Java》里面寫的嗎?果然每天增刪改太low了”

要了解這些圖嗎?

我希望能解釋的再簡單一些,以上都不用
Java 并發(fā)代碼
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。如果這個地方想不明白,就請留言,或者看看文章頂部那些原理圖。

要不簡單點,記住“多線程對全局變量的寫操作會發(fā)生沖突”。
答案,聲明原子變量 AtomicInteger count
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

相關(guān)文章

  • Java并發(fā)面試幸虧有點道行不然又被忽悠

    摘要:前言面試,必然要被問內(nèi)存模型和并發(fā)開發(fā)。但是線程池啟動多線程,是并發(fā)執(zhí)行的。線程線程同時對值為的變量進行操作,結(jié)果返回,而不是。要不簡單點,記住多線程對全局變量的寫操作會發(fā)生沖突。 前言 面試Java,必然要被問Java內(nèi)存模型和Java并發(fā)開發(fā)。我被問到的時候,心里慌得一批,額,是在《Thinking in Java》里面寫的嗎?果然每天增刪改太low了 要了解這些圖嗎? showI...

    jsbintask 評論0 收藏0
  • 漫畫:程序員的“情人”節(jié)應(yīng)該這樣度過

    摘要:今天是年月號,一年一度的情人節(jié)又來了,今天對于很多年輕人來說是個特別的日子。該程序員在聯(lián)誼會上認識了某藝術(shù)系女生,同鄉(xiāng)的雙方互有好感。 今天是2018年8月17號,一年一度的情人節(jié)又來了,今天對于很多年輕人來說是個特別的日子。但是作為屌絲界的一枚程序員,往往給人的印象是宅,不愛說話,智商不好,也不討好哄女孩子歡心。但是,為什么我身邊的程序員各個都是高智商,高顏值的小碼農(nóng)呢?或許,他們用...

    Shisui 評論0 收藏0
  • Android自定義權(quán)限使用總結(jié)

    摘要:使用場景自定義權(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...

    RobinQu 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<