成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

java-實戰(zhàn)java高并發(fā)程序設計-ch2java并行程序基礎(chǔ)

yy13818512006 / 368人閱讀

摘要:所以需要等來確保程序中隱蔽的錯誤沒有提示的錯誤比如兩個正數(shù)相加,溢出導致其值為負數(shù)。并發(fā)下的兩個線程同時對一個對象,每個線程個對象,最終結(jié)果可能中有萬個對象。可能對象個數(shù)少于萬可能內(nèi)部結(jié)構(gòu)發(fā)生破壞,程序無法終止,會被大量消耗。

java并行程序基礎(chǔ)

參考:
https://github.com/chengbingh...

2.1 有關(guān)線程, 需要知道的事

進程是線程的容器
線程狀態(tài)圖:


2.2 線程的基本操作
2.2.1新建線程
2.2.2終止線程
stop 暴力終止線程,廢棄方法


2.2.3線程中斷
方法:

2.2.4 等待(wait)和喚醒notify
注意:
wait 是object的一個方法,調(diào)用wait方法的對象,必須在synchronized 中,因為要獲取它的監(jiān)視器。
wait會釋放鎖

public class SimpleWN {

    final static Object obj = new Object();
    
    public static void main(String[] args) {

        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                synchronized(obj) {
                    System.out.println("t1.start,and t1 will wait");
                    try {
                        // 調(diào)用wait 方法的這個對象必須被synchronizeed
                        //wait 會釋放鎖
                        obj.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("t1 was notify");


                }

            }
        });

        Thread t2 = new Thread(new Runnable() {
            @Override
            public void run() {
                synchronized(obj){
                    System.out.println("t2 start and will notify t1");
                    // 調(diào)用notify 方法的這個對象必須被synchronizeed
                    //如果 有n個線程此時都是由于調(diào)用了obj.wait方法,那么會喚醒任意一個
                    obj.notify();
                    try {
                        Thread.sleep(2000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }

                    System.out.println("t2 end run");
                }
            }
        });
        t1.start();
        t2.start();
    }
}
輸出:注意鎖
t1.start,and t1 will wait
t2 start and will notify t1
t2 end run
t1 was notify

2.2.5 掛起(suspend)和繼續(xù)執(zhí)行(resume)
suspend()和resume方法

2.2.6 join 和yeild
join:加入,把線程當做一個方法了。
yeild:讓出線程執(zhí)行權(quán),但是還是會爭奪線程的執(zhí)行權(quán)

2.3 volatile 與java 內(nèi)存模型(JMM)

JMM: 原子性,可見性,有序性
原子性:32位虛擬機中多線程讀寫long不會有問題,但是不能保證i++

可見性:
虛擬機在-server模式下會進行優(yōu)化,下面的程序永遠不會跳出。

/**
 * @author ChengBing Han
 * @date 9:39  2018/6/22
 * @description
 */
public class NoVisibility {
    private static boolean ready;
    private static int number;


    private static class ReaderThread extends Thread {
        public void run() {

            /*
           while (!ready){
                System.out.println(new Date());
            }*/
            //這個和上述的優(yōu)化不同,這個在-server模式下會優(yōu)化
            while (!ready) ;
            System.out.println(number);
        }

    }

    public static void main(String[] args) throws InterruptedException {
        
        //永遠不會終止程序
        new ReaderThread().start();
        Thread.sleep(1000);
        number = 42;
        ready = true;
        Thread.sleep(2000);
    }
}

備注:上述ready 用volatile 修飾后就會退出,或者用-client 模式啟動虛擬機

2.4 分門別類的管理 線程組 2.5 駐守線程的后臺:守護線程 2.6 線程優(yōu)先級:先干重要的事

1-10,優(yōu)先級逐漸升高

2.7 synchronized(內(nèi)部鎖)
volatile 可以保證原子性,和可見性,但是如果兩個線程同時修改了某個變量,那么還是無法識別的,這時volatile的局限性。所以需要synchronized等來確保

2.8 程序中隱蔽的錯誤

2.8.1 沒有提示的錯誤e
比如兩個正數(shù)int 相加, 溢出導致 其值為負數(shù)。

2.8.2 并發(fā)下的ArrayList
兩個線程同時對一個ArrayList add 對象,每個線程add 10000 個對象, 最終結(jié)果
可能1:ArrayList 中有2萬個對象。
可能2:拋出異常
ArrayList 內(nèi)部結(jié)構(gòu)被破壞了

可能3:ArrayList 中的對象個數(shù)小于2萬

2.8.3 并發(fā)下的HashMap
兩個線程同時對HashMap添加對象,每個線程add 10000 個對象,最終結(jié)果
可能1:HashMap 中有2萬個對象。
可能2:對象個數(shù)少于2萬
可能3:HashMap內(nèi)部結(jié)構(gòu)發(fā)生破壞,程序無法終止,cpu會被大量消耗。
2.8.4 錯誤加鎖

static Integer i = 0;
.........
synchronized(i){
   i++;
}
//問題在于, integer是不可變的,所以每次i++都會創(chuàng)建一個新的對象??梢杂胘avap 反編譯查看

允許多個線程同時訪問:信號量

允許幾個線程訪問

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/71270.html

相關(guān)文章

  • java-實戰(zhàn)java并發(fā)程序設計-ch1走入并行的世界

    摘要:參考何去何從的并行計算忘記該死的并行并行程序的復雜性和亂序性,并行程序設計十分復雜??膳碌默F(xiàn)實摩爾定律的失效單核上的晶體管數(shù)目達到極限。并發(fā)級別阻塞重入鎖無饑餓兩個線程優(yōu)先級不同,低優(yōu)先級的可能產(chǎn)生饑餓。 Chapter1 參考:https://github.com/chengbingh... 1.1何去何從的并行計算 1.1.1 忘記該死的并行并行程序的復雜性和亂序性,并行程序設計十...

    suxier 評論0 收藏0
  • 實戰(zhàn)java并發(fā)程序設計第一章

    摘要:通過指令重排可以減少流水線停頓提升巨大效率原則程序順序原則一個線程內(nèi)保證語義的串行性。鎖規(guī)則解鎖必然發(fā)生在隨后的加鎖前。線程的方法先于它的每一個動作。 1. 基本概念 同步(Synchronous)和異步(Asynchronous) 并發(fā)(Conncurrency)和并行(Parallelism) 臨界區(qū) 阻塞(Blocking)與非阻塞(Non-Blocking) 死鎖(Deadl...

    moven_j 評論0 收藏0
  • 如何提Java并行程序性能

    摘要:因此將變量存放于獨立的緩存行中,也有助于變量在多線程訪問是的性能提升實戰(zhàn)高并發(fā)程序設計,大量的高并發(fā)庫都會采用這種技術(shù)。 在Java程序中,多線程幾乎已經(jīng)無處不在。與單線程相比,多線程程序的設計和實現(xiàn)略微困難,但通過多線程,我們卻可以獲得多核CPU帶來的性能飛躍,從這個角度說,多線程是一種值得嘗試的技術(shù)。那么如何寫出高效的多線程程序呢? 有關(guān)多線程的誤區(qū):線程越多,性能越好 不少初學者...

    everfight 評論0 收藏0
  • 后端好書閱讀與推薦(續(xù)三)

    摘要:后端好書閱讀與推薦系列文章后端好書閱讀與推薦后端好書閱讀與推薦續(xù)后端好書閱讀與推薦續(xù)二后端好書閱讀與推薦續(xù)三這里依然記錄一下每本書的亮點與自己讀書心得和體會,分享并求拍磚。然后又請求封鎖,當釋放了上的封鎖之后,系統(tǒng)又批準了的請求一直等待。 后端好書閱讀與推薦系列文章:后端好書閱讀與推薦后端好書閱讀與推薦(續(xù))后端好書閱讀與推薦(續(xù)二)后端好書閱讀與推薦(續(xù)三) 這里依然記錄一下每本書的...

    lauren_liuling 評論0 收藏0
  • 后端好書閱讀與推薦(續(xù)三)

    摘要:后端好書閱讀與推薦系列文章后端好書閱讀與推薦后端好書閱讀與推薦續(xù)后端好書閱讀與推薦續(xù)二后端好書閱讀與推薦續(xù)三這里依然記錄一下每本書的亮點與自己讀書心得和體會,分享并求拍磚。然后又請求封鎖,當釋放了上的封鎖之后,系統(tǒng)又批準了的請求一直等待。 后端好書閱讀與推薦系列文章:后端好書閱讀與推薦后端好書閱讀與推薦(續(xù))后端好書閱讀與推薦(續(xù)二)后端好書閱讀與推薦(續(xù)三) 這里依然記錄一下每本書的...

    ckllj 評論0 收藏0

發(fā)表評論

0條評論

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