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

資訊專欄INFORMATION COLUMN

Java多線程基礎(四)——Immutable模式

mmy123456 / 2753人閱讀

摘要:在中,有著能夠保證實例狀態(tài)絕不會改變的類類。二模式案例案例類,具有姓名地址等字段。而不需要使用保護的最大優(yōu)點就是可在不喪失安全性與生命性的前提下,提高程序的執(zhí)行性能。若實例由多數(shù)線程所共享,且訪問非常頻繁,模式就能發(fā)揮極大的優(yōu)點。

一、定義

Immutable是“永恒的”“不會改變”的意思。在Immutable Patttern中,有著能夠保證實例狀態(tài)絕不會改變的類(immutable 類)。因為訪問這個實例時,可以省去使用共享互斥機制所會浪費的時間,提高系統(tǒng)性能。java.lang.String就是一個Immutable的類。

二、模式案例

案例:
Person類,具有姓名(name)、地址(address)等字段。字段都是私有的,只能通過構造器來設置,且只有get方法,沒有set方法。這時,即使有多個線程同時訪問相同實例,Person類也是安全的,它的所有方法都不需要定義成synchronized。

Person定義:

public final class Person {
    private final String name;
    private final String address;
    public Person(String name, String address) {
        this.name = name;
        this.address = address;
    }
    public String getName() {
        return name;
    }
    public String getAddress() {
        return address;
    }
    public String toString() {
        return "[ Person: name = " + name + ", address = " + address + " ]";
    }
}

線程定義:

public class PrintPersonThread extends Thread {
    private Person person;
    public PrintPersonThread(Person person) {
        this.person = person;
    }
    public void run() {
        while (true) {
            System.out.println(Thread.currentThread().getName() + " prints " + person);
        }
    }
}

執(zhí)行:

public class Main {
    public static void main(String[] args) {
        Person alice = new Person("Alice", "Alaska");
        new PrintPersonThread(alice).start();
        new PrintPersonThread(alice).start();
        new PrintPersonThread(alice).start();
    }
}
三、模式講解

Immutable模式的角色如下:

Immutable(不變的)參與者

Immutable參與者是一個字段值無法更改的類,也沒有任何用來更改字段值的方法。當Immutable參與者的實例建立后,狀態(tài)就完全不再變化。

適用場景:
Immutable模式的優(yōu)點在于,“不需要使用synchronized保護”。而“不需要使用synchronized保護”的最大優(yōu)點就是可在不喪失安全性與生命性的前提下,提高程序的執(zhí)行性能。若實例由多數(shù)線程所共享,且訪問非常頻繁,Immutable模式就能發(fā)揮極大的優(yōu)點。

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

轉載請注明本文地址:http://systransis.cn/yun/71487.html

相關文章

  • Java線程進階(十)—— J.U.C之atomic框架:AtomicReference

    摘要:但是,有些操作會依賴于對象的變化過程,此時的解決思路一般就是使用版本號。在變量前面追加上版本號,每次變量更新的時候把版本號加一,那么就會變成。四的引入就是上面所說的加了版本號的。 showImg(https://segmentfault.com/img/remote/1460000016012188); 本文首發(fā)于一世流云的專欄:https://segmentfault.com/blo...

    aboutU 評論0 收藏0
  • Java程序員金三銀精心挑選的300余道Java面試題與答案

    摘要:為程序員金三銀四精心挑選的余道面試題與答案,歡迎大家向我推薦你在面試過程中遇到的問題我會把大家推薦的問題添加到下面的常用面試題清單中供大家參考。 為Java程序員金三銀四精心挑選的300余道Java面試題與答案,歡迎大家向我推薦你在面試過程中遇到的問題,我會把大家推薦的問題添加到下面的常用面試題清單中供大家參考。 前兩天寫的以下博客,大家比較認可,熱度不錯,希望可以幫到準備或者正在參加...

    tomorrowwu 評論0 收藏0
  • Java學習路線總結,搬磚工逆襲Java架構師(全網最強)

    摘要:哪吒社區(qū)技能樹打卡打卡貼函數(shù)式接口簡介領域優(yōu)質創(chuàng)作者哪吒公眾號作者架構師奮斗者掃描主頁左側二維碼,加入群聊,一起學習一起進步歡迎點贊收藏留言前情提要無意間聽到領導們的談話,現(xiàn)在公司的現(xiàn)狀是碼農太多,但能獨立帶隊的人太少,簡而言之,不缺干 ? 哪吒社區(qū)Java技能樹打卡?【打卡貼 day2...

    Scorpion 評論0 收藏0
  • 并發(fā)基礎

    摘要:關于,這個方法只會喚醒一個線程,并且不允許指定喚醒哪個線程,這是可能會發(fā)生死鎖的。使用不可變對象降低了垃圾回收所產生的額外開銷,同時也可以減少一些為了維護在并發(fā)中的的代碼開銷。 前言 跟著 The Java Tutorials 把并發(fā)的一些基礎過了一遍,發(fā)現(xiàn)仍然還是有很多不清楚的地方,主要是因為平常沒有機會實際應用吧,理論知識要有,實踐也很重要,哪怕是寫些小 demo 也可以的。 雖然...

    Warren 評論0 收藏0
  • Java問題匯總,持續(xù)更新到GitHub

    摘要:目錄介紹問題匯總具體問題好消息博客筆記大匯總年月到至今,包括基礎及深入知識點,技術博客,學習筆記等等,還包括平時開發(fā)中遇到的匯總,當然也在工作之余收集了大量的面試題,長期更新維護并且修正,持續(xù)完善開源的文件是格式的同時也開源了生活博客,從年 目錄介紹 00.Java問題匯總 01.具體問題 好消息 博客筆記大匯總【16年3月到至今】,包括Java基礎及深入知識點,Android技...

    beita 評論0 收藏0

發(fā)表評論

0條評論

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