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

資訊專欄INFORMATION COLUMN

出場率比較高的一道多線程安全面試題

xiyang / 2370人閱讀

摘要:程序正常運行,輸出了預期容量的大小這是正常運行結果,未發生多線程安全問題,但這是不確定性的,不是每次都會達到正常預期的。另外,像等都有類似多線程安全問題,在多線程并發環境下避免使用這種集合。

這個問題是 Java 程序員面試經常會遇到的吧。

工作一兩年的應該都知道 ArrayList 是線程不安全的,要使用線程安全的就使用 Vector,這也是各種 Java 面試寶典里面所提及的,可能很多工作好幾年的程序員都停留在這個知識面上。

先說說為什么 ArrayList 是線程不安全的吧,來看以下的代碼。

/**
 * 微信公眾號:Java技術棧
 */
public class TestArrayList {

    private static List list = new ArrayList<>();

    public static void main(String[] args) throws InterruptedException {
        for (int i = 0; i < 10; i++) {
            testList();
            list.clear();
        }
    }

    private static void testList() throws InterruptedException {
        Runnable runnable = () -> {
            for (int i = 0; i < 10000; i++) {
                list.add(i);
            }
        };

        Thread t1 = new Thread(runnable);
        Thread t2 = new Thread(runnable);
        Thread t3 = new Thread(runnable);

        t1.start();
        t2.start();
        t3.start();

        t1.join();
        t2.join();
        t3.join();

        System.out.println(list.size());
    }

}

這是它的輸出結果,我們期望的結果應該都是:30000,然后并不是,這就是傳說中的多線程并發問題了。

Exception in thread "Thread-1" java.lang.ArrayIndexOutOfBoundsException: 15786
    at java.base/java.util.ArrayList.add(ArrayList.java:468)
    at java.base/java.util.ArrayList.add(ArrayList.java:480)
    at com.test.thread.TestArrayList.lambda$testList$0(TestArrayList.java:23)
    at java.base/java.lang.Thread.run(Thread.java:844)
20332
16100
14941
23749
15631
22118
27417
30000
28691
27843
現象分析

從以上結果可以總結出 ArrayList 在并發情況下會出現的幾種現象。

1、發生 ArrayIndexOutOfBoundsException 異常;

private void add(E e, Object[] elementData, int s) {
    if (s == elementData.length)
        elementData = grow();
    elementData[s] = e;
    size = s + 1;
}

定位到異常所在源代碼,毫無疑問,問題是出現在多線程并發訪問下,由于沒有同步鎖的保護,造成了 ArrayList 擴容不一致的問題。

2、程序正常運行,輸出了少于實際容量的大小;

這個也是多線程并發賦值時,對同一個數組索引位置進行了賦值,所以出現少于預期大小的情況。

3、程序正常運行,輸出了預期容量的大小;

這是正常運行結果,未發生多線程安全問題,但這是不確定性的,不是每次都會達到正常預期的。

解決方案

既然這樣,那么在高并發情況下,使用什么樣的列表集合保護線程安全呢?回到文章最開始的地方,使用 Vector,還有別的嗎?當然有,篇幅有限,請各位看官期待后續文章。

另外,像 HashMap, HashSet 等都有類似多線程安全問題,在多線程并發環境下避免使用這種集合。

轉載請注明原文實際來源地址:原文地址

引用文字

資料:成為架構師的十階段學習資料!

教程:史上最強 Spring Boot & Cloud 教程匯總

工具:推薦一款在線創作流程圖、思維導圖軟件

掃描關注我們的微信公眾號,回復 "666" 可獲取一套Java并發編程高清視頻教程。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/71582.html

相關文章

  • 推薦:7 月份值得一看的 Java 技術干貨!

    摘要:月底了,又到了我們總結這一個月技術干貨的時候了,又到了我們給粉絲免費送書的日子了。 月底了,又到了我們總結這一個月 Java 技術干貨的時候了,又到了我們給粉絲免費送書的日子了。 7 月份干貨總結 Oracle 發布了一個全棧虛擬機 GraalVM 一文帶你深入拆解 Java 虛擬機 圖文帶你了解 8 大排序算法 Spring Boot 2.x 新特性總結及遷移指南 Spring B...

    saucxs 評論0 收藏0
  • 三年Java后端面試經歷

    摘要:前言三年后端開發經驗,面的目標崗位是的高級后端開發。面試結束,應該沒有后續。 前言 三年Java后端開發經驗,面的目標崗位是20k-35k的高級后端Java開發。 第一場,基本裸面,關于曾經的項目部門答的不好,所以還是得好好準備。 某C輪在線旅游公司 筆試 先做半個小時的筆試題,一共六個題目,兩道go語言的基礎題,一道斐波那契相關,一道數據庫行列轉置,一道實現一個棧,還有一道是百萬計...

    darry 評論0 收藏0
  • 一道CSS筆試題

    摘要:分析這道題主要考察的居中和寬高等比例。如果元素的高度和寬度都以某一個值作為參照系,那么理論上元素的乘以可自定義。根據規范,的值為百分比時,是相對于父元素的寬度而言。 showImg(https://segmentfault.com/img/remote/1460000011668870?w=942&h=552);如上圖所示,屏幕正中間有個元素A,隨著屏幕寬度的增加,始終需要滿足以下條件...

    aikin 評論0 收藏0
  • 一道setTimeout async promise執行順序的筆試題引發的思考

    摘要:如果你要問他和誰當進去的快,要從下面兩個方面考慮結束時。至于什么,查了很多的資料,了解到一個瀏覽器環境只能有一個事件循環,而一個事件循環可以有多個任務隊列。 ====據說這是今日頭條去年的一道筆試題,主要考察的是setTimeout async promise執行順序 ~先雙手奉上這道題目~ async function async1() { consol...

    soasme 評論0 收藏0
  • 史上最全阿里 Java 面試題總結

    摘要:以下為大家整理了阿里巴巴史上最全的面試題,涉及大量面試知識點和相關試題。的內存結構,和比例。多線程多線程的幾種實現方式,什么是線程安全。點擊這里有一套答案版的多線程試題。線上系統突然變得異常緩慢,你如何查找問題。 以下為大家整理了阿里巴巴史上最全的 Java 面試題,涉及大量 Java 面試知識點和相關試題。 JAVA基礎 JAVA中的幾種基本數據類型是什么,各自占用多少字節。 S...

    winterdawn 評論0 收藏0

發表評論

0條評論

xiyang

|高級講師

TA的文章

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