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

資訊專欄INFORMATION COLUMN

java 線程同步

xushaojieaaa / 1979人閱讀

摘要:為什么線程同步當(dāng)我們有多個(gè)線程要對(duì)同一個(gè)資源進(jìn)行操作的時(shí)候,比如說(shuō)文件,這時(shí)候就不能讓多個(gè)線程同時(shí)操作這個(gè)文件了。程序完善要解決上面出現(xiàn)的問(wèn)題,就要用到我們最開(kāi)始說(shuō)的線程同步了。通過(guò)這個(gè)關(guān)鍵字,我們就能在執(zhí)行方法的時(shí)候,實(shí)現(xiàn)線程同步了。

為什么線程同步

當(dāng)我們有多個(gè)線程要對(duì)同一個(gè)資源進(jìn)行操作的時(shí)候,比如說(shuō)文件,這時(shí)候就不能讓多個(gè)線程同時(shí)操作這個(gè)文件了。因?yàn)楫?dāng)文件共享的時(shí)候,多個(gè)操作就會(huì)產(chǎn)生沖突。相信使用過(guò)git進(jìn)行團(tuán)隊(duì)開(kāi)發(fā)的人就會(huì)有比價(jià)深刻的體會(huì)。

這時(shí)候就需要引入線程的同步機(jī)制。

所謂同步,是指一個(gè)一個(gè)執(zhí)行,也就是排隊(duì),幾個(gè)線程排隊(duì)執(zhí)行,讓線程之間有一個(gè)先來(lái)后到的關(guān)系。這樣,就不會(huì)產(chǎn)生爭(zhēng)搶的現(xiàn)象,也就不會(huì)出現(xiàn)沖突。

問(wèn)題描述

一個(gè)有兩個(gè)線程的程序,第一個(gè)線程計(jì)算2~1000之間的偶數(shù)及個(gè)數(shù),第二個(gè)線程計(jì)算1000~2000之間的偶數(shù)及個(gè)數(shù)。

初步實(shí)現(xiàn)

首先,我們根據(jù)題目來(lái)設(shè)計(jì)一下實(shí)現(xiàn)方式。

1.定義兩個(gè)線程。這里要定義自己的線程類,然后去設(shè)置計(jì)算偶數(shù)的開(kāi)始和結(jié)束
2.實(shí)現(xiàn)計(jì)算所給范圍內(nèi)的偶數(shù)和偶數(shù)個(gè)數(shù)
3.執(zhí)行線程

可以看到實(shí)現(xiàn)方式很簡(jiǎn)單。初步實(shí)現(xiàn)如下:

1.定義自己的線程類:
public class MyTread extends Thread {
    private int begin;          // 范圍開(kāi)始
    private int end;            // 范圍結(jié)束

    public MyTread(int begin, int end) {
        this.begin = begin;
        this.end = end;
    }
}
2.實(shí)現(xiàn)計(jì)算偶數(shù)以及偶數(shù)個(gè)數(shù)
@Override
public void run() {
    this.getEven(begin, end);
}

// 獲取偶數(shù)以及個(gè)數(shù)
private void getEven(int begin, int end) {
    int count = 0;
    System.out.println(begin + "~" + end + "之間的偶數(shù)為:");
    if (begin % 2 != 0) {
        begin += 1;
    }

    for (; begin <= end; begin += 2) {
        System.out.print(begin + " ");
        count++;
    }

    System.out.println();
    System.out.println("偶數(shù)個(gè)數(shù)為:" + count);
}
3.初始化線程,運(yùn)行
public static void main(String[] args) {
    MyTread tread1 = new MyTread(2, 500);
    MyTread tread2 = new MyTread(500, 1000);
    tread1.start();
    tread2.start();
}

注:這里為了展示后面的效果,所以將數(shù)字范圍減小。

看一下結(jié)果:

好像并不是我們想要的效果。我們想要這樣的效果:

我們想要每一部分的偶數(shù)和偶數(shù)個(gè)數(shù)都在一起,但是我們實(shí)現(xiàn)后的效果確實(shí)兩部分混亂出現(xiàn)的。

程序完善

要解決上面出現(xiàn)的問(wèn)題,就要用到我們最開(kāi)始說(shuō)的線程同步了。

根據(jù)我們開(kāi)始的介紹,發(fā)現(xiàn)實(shí)現(xiàn)同步的一個(gè)條件就是有一個(gè)共享的資源。那么我們的代碼里什么是這個(gè)共享的資源呢?貌似沒(méi)有。所以先創(chuàng)建一個(gè)。

1.建立共享資源

我們這里的共享資源完全就可以是同一個(gè)對(duì)象,所以我們就另外建立一個(gè)類,用來(lái)示例共享資源。

public class Even {}
2.然后在共享類中建立計(jì)算偶數(shù)的方法:
public class Even {
    /**
     * 獲取某個(gè)范圍內(nèi)偶數(shù)以及個(gè)數(shù)
     * @param begin 統(tǒng)計(jì)開(kāi)始
     * @param end   統(tǒng)計(jì)結(jié)束
     */
    public synchronized void getEven(int begin, int end) {
        int count = 0;
        System.out.println(begin + "~" + end + "之間的偶數(shù)為:");
        if (begin % 2 != 0) {
            begin += 1;
        }

        for (; begin <= end; begin += 2) {
            System.out.print(begin + " ");
            count++;
        }

        System.out.println();
        System.out.println("偶數(shù)個(gè)數(shù)為:" + count);
    }
}

細(xì)心的人會(huì)發(fā)現(xiàn),這個(gè)方法跟我們最開(kāi)始寫(xiě)的方法有點(diǎn)不同,它多了一個(gè)關(guān)鍵字:synchronized。通過(guò)這個(gè)關(guān)鍵字,我們就能在執(zhí)行方法的時(shí)候,實(shí)現(xiàn)線程同步了。

3.最后在線程中調(diào)用共享方法
public class MyTread extends Thread {
    Even even;
    
    @Override
    public void run() {
        even.getEven(begin, end);
    }
}

這時(shí)候,我們?cè)賮?lái)執(zhí)行一下:

實(shí)現(xiàn)了我們想要的效果。

最后,附上完整代碼:

/**
 * 偶數(shù)類
 */
public class Even {
    /**
     * 獲取某個(gè)范圍內(nèi)偶數(shù)以及個(gè)數(shù)
     * @param begin 統(tǒng)計(jì)開(kāi)始
     * @param end   統(tǒng)計(jì)結(jié)束
     */
    public synchronized void getEven(int begin, int end) {
        int count = 0;
        System.out.println(begin + "~" + end + "之間的偶數(shù)為:");
        if (begin % 2 != 0) {
            begin += 1;
        }

        for (; begin <= end; begin += 2) {
            System.out.print(begin + " ");
            count++;
        }

        System.out.println();
        System.out.println("偶數(shù)個(gè)數(shù)為:" + count);
    }
}

public class MyTread extends Thread {
    Even even;
    private int begin;          // 范圍開(kāi)始
    private int end;            // 范圍結(jié)束

    public MyTread(Even even, int begin, int end) {
        this.even = even;
        this.begin = begin;
        this.end = end;
    }

    @Override
    public void run() {
        even.getEven(begin, end);
    }

    public static void main(String[] args) {
        Even even = new Even();
        MyTread tread1 = new MyTread(even, 2, 500);
        MyTread tread2 = new MyTread(even, 500, 1000);
        tread1.start();
        tread2.start();
    }
}

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

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

相關(guān)文章

  • Java同步塊簡(jiǎn)介

    摘要:同步塊用來(lái)避免競(jìng)爭(zhēng)。實(shí)際需要那種同步塊視具體情況而定。在非同步的方法中的同步塊的例子如下所示示例使用同步塊構(gòu)造器來(lái)標(biāo)記一塊代碼是同步的。在同步構(gòu)造器中用括號(hào)括起來(lái)的對(duì)象叫做監(jiān)視器對(duì)象。他們的構(gòu)造器引用同一個(gè)實(shí)例。 Java 同步塊(synchronized block)用來(lái)標(biāo)記方法或者代碼塊是同步的。Java同步塊用來(lái)避免競(jìng)爭(zhēng)。本文介紹以下內(nèi)容: Java同步關(guān)鍵字(synchro...

    warnerwu 評(píng)論0 收藏0
  • Java中的synchronized關(guān)鍵字

    摘要:的關(guān)鍵字中的塊使用關(guān)鍵字進(jìn)行標(biāo)記。由于每個(gè)類只有一個(gè)類對(duì)象存在于中,因此全局同時(shí)只有一個(gè)線程能夠進(jìn)入到同一個(gè)類的靜態(tài)同步方法中。同步代碼塊使這種期望成為可能。注意同步代碼塊如何在括號(hào)中接受一個(gè)對(duì)象。相同的實(shí)例被傳入兩個(gè)不同的線程實(shí)例中。 Java的synchronized塊標(biāo)記一個(gè)方法或一個(gè)代碼塊為同步的。synchronized塊能用于防止出現(xiàn)競(jìng)態(tài)條件。 Java的synchroni...

    lylwyy2016 評(píng)論0 收藏0
  • 線程安全

    摘要:不可變?cè)谥?,不可變的?duì)象一定是線程安全的。在里標(biāo)注自己是線程安全的類,大多都不是絕對(duì)線程安全,比如某些情況下類在調(diào)用端也需要額外的同步措施。無(wú)同步方案要保證線程安全,不一定就得需要數(shù)據(jù)的同步,兩者沒(méi)有因果關(guān)系。 在之前學(xué)習(xí)編程的時(shí)候,有一個(gè)概念根深蒂固,即程序=算法+數(shù)據(jù)結(jié)構(gòu)。數(shù)據(jù)代表問(wèn)題空間中的客體,代碼就用來(lái)處理這些數(shù)據(jù),這種思維是站在計(jì)算機(jī)的角度去抽象問(wèn)題和解決問(wèn)題,稱之為面向過(guò)...

    fuyi501 評(píng)論0 收藏0
  • JAVA線程和并發(fā)基礎(chǔ)面試問(wèn)答

    摘要:多線程和并發(fā)問(wèn)題是技術(shù)面試中面試官比較喜歡問(wèn)的問(wèn)題之一。線程可以被稱為輕量級(jí)進(jìn)程。一個(gè)守護(hù)線程是在后臺(tái)執(zhí)行并且不會(huì)阻止終止的線程。其他的線程狀態(tài)還有,和。上下文切換是多任務(wù)操作系統(tǒng)和多線程環(huán)境的基本特征。 多線程和并發(fā)問(wèn)題是 Java 技術(shù)面試中面試官比較喜歡問(wèn)的問(wèn)題之一。在這里,從面試的角度列出了大部分重要的問(wèn)題,但是你仍然應(yīng)該牢固的掌握J(rèn)ava多線程基礎(chǔ)知識(shí)來(lái)對(duì)應(yīng)日后碰到的問(wèn)題。(...

    dreamans 評(píng)論0 收藏0
  • JAVA線程和并發(fā)基礎(chǔ)

    摘要:線程可以被稱為輕量級(jí)進(jìn)程。一個(gè)守護(hù)線程是在后臺(tái)執(zhí)行并且不會(huì)阻止終止的線程。其他的線程狀態(tài)還有,和。上下文切換是多任務(wù)操作系統(tǒng)和多線程環(huán)境的基本特征。在的線程中并沒(méi)有可供任何對(duì)象使用的鎖和同步器。 原文:Java Multi-Threading and Concurrency Interview Questions with Answers 翻譯:并發(fā)編程網(wǎng) - 鄭旭東 校對(duì):方騰飛 多...

    vboy1010 評(píng)論0 收藏0
  • java并發(fā)編程學(xué)習(xí)1--基礎(chǔ)知識(shí)

    摘要:死亡狀態(tài)線程退出有可能是正常執(zhí)行完成也有可能遇見(jiàn)異常退出。類有新建與死亡狀態(tài)返回其余狀態(tài)返回判斷線程是否存活。線程因某些原因進(jìn)入阻塞狀態(tài)。執(zhí)行同步代碼塊的過(guò)程中執(zhí)行了當(dāng)前線程放棄開(kāi)始睡眠進(jìn)入就緒狀態(tài)但是不會(huì)釋放鎖。 【java內(nèi)存模型簡(jiǎn)介 JVM中存在一個(gè)主存區(qū)(Main Memory或Java Heap Memory),Java中所有變量都是存在主存中的,對(duì)于所有線程進(jìn)行共享,而每個(gè)...

    huangjinnan 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<