亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

Java多線程由易到難

Mertens / 1129人閱讀

摘要:線程可以驅(qū)動(dòng)任務(wù),因此你需要一種描述任務(wù)的方式,這可以由接口來提供。線程調(diào)度沒有順序的,由決定。首先會(huì)按照需要?jiǎng)?chuàng)建足夠多的線程來執(zhí)行任務(wù)。這個(gè)程序?qū)⒃谥械乃腥蝿?wù)完成之后盡快退出。就像是線程數(shù)量為的。

線程可以驅(qū)動(dòng)任務(wù),因此你需要一種描述任務(wù)的方式,這可以由Runnable接口來提供。要想定義任務(wù),只需實(shí)現(xiàn)Runnable接口并編寫run方法,使得該任務(wù)可以執(zhí)行你的命令。

    
public class LiftOff implements Runnable {

    protected int countDown = 10;
    private static int taskCount = 0;
    
    //id可以用來區(qū)分任務(wù)的多個(gè)實(shí)例
    private final int id = taskCount++;
    
    public LiftOff(){
        System.out.println("調(diào)用了無參的構(gòu)造函數(shù)");  
    }
    
    public LiftOff(int countDown){
        this.countDown = countDown;
        System.out.println("調(diào)用了有參的構(gòu)造函數(shù)
"+  
                 "參數(shù)內(nèi)容為:"+countDown);  
    }
    
    public String status(){
        
        return "#" + id + "(" + (countDown > 0 ? countDown : "Liftoff!") + "),";
        
    }

    @Override
    public void run() {
        
        while(countDown-- > 0){
            System.out.println(status());
            
            //使當(dāng)前線程從執(zhí)行狀態(tài)(運(yùn)行狀態(tài))變?yōu)榭蓤?zhí)行態(tài)(就緒狀態(tài))。
            //cpu會(huì)從眾多的可執(zhí)行態(tài)里選擇,也就是說,
            //當(dāng)前也就是剛剛的那個(gè)線程還是有可能會(huì)被再次執(zhí)行到的,
            //并不是說一定會(huì)執(zhí)行其他線程而該線程在下一次中不會(huì)執(zhí)行到了。
            Thread.yield();
        }
        
    }
    
    public static void main(String[] args) {
        LiftOff test1 = new LiftOff();
        test1.run();
        System.out.println("
");
        LiftOff test2 = new LiftOff(5);
        test2.run();
    }


}

將Runnable對(duì)象轉(zhuǎn)變?yōu)楣ぷ魅蝿?wù)的傳統(tǒng)方式是把它提交給一個(gè)Thread構(gòu)造器,
Thread構(gòu)造器只需要一個(gè)Runnable對(duì)象。調(diào)用Thread對(duì)象的start()方法為該線程執(zhí)行必需的初始化操作,
然后調(diào)用Runnable的run()方法,以便在這個(gè)新線程中啟動(dòng)該任務(wù)。因?yàn)閙ain()方法和LiftOff.run()是由不同
的線程執(zhí)行的,因此程序同時(shí)運(yùn)行兩個(gè)方法。

線程調(diào)度沒有順序的,由CPU決定。

接下來通過java.util.concurrent包中的執(zhí)行器(Executor)將為你管理Thread對(duì)象,從而簡(jiǎn)化了并發(fā)編程。

1:CachedThreadPool首先會(huì)按照需要?jiǎng)?chuàng)建足夠多的線程來執(zhí)行任務(wù)(Task)。隨著程序執(zhí)行的過程,有的線程執(zhí)行完了任務(wù),可以被重新循環(huán)使用時(shí),才不再創(chuàng)建新的線程來執(zhí)行任務(wù)

對(duì)shutdown()方法的調(diào)用可以防止新任務(wù)被提交給這個(gè)Executor,當(dāng)前線程(即驅(qū)動(dòng)main()的線程)將
繼續(xù)運(yùn)行在shutdown()被調(diào)用之前提交的所有任務(wù)。這個(gè)程序?qū)⒃贓xecutor中的所有任務(wù)完成之后盡快退出。

2:FixedThreadPool模式會(huì)使用一個(gè)優(yōu)先固定數(shù)目的線程來處理若干數(shù)目的任務(wù)。規(guī)定數(shù)目的線程處理所有任務(wù),一旦有線程處理完了任務(wù)就會(huì)被用來處理新的任務(wù)(如果有的話)。

最好把3換成Runtime.getRuntime().availableProcessors(),這樣能更大程度利用你的電腦CPU處理。

3:SingleThreadExecutor就像是線程數(shù)量為1的FixedThreadPool。如果多個(gè)任務(wù)被提交給SingleThreadExecutor的話,那么這些任務(wù)會(huì)被保存在一個(gè)隊(duì)列中,并且會(huì)按照任務(wù)提交的順序,一個(gè)先執(zhí)行完成再執(zhí)行另外一個(gè)線程。SingleThreadExecutor模式可以保證只有一個(gè)任務(wù)會(huì)被執(zhí)行。這種特點(diǎn)可以被用來處理共享資源的問題而不需要考慮同步的問題。

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

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

相關(guān)文章

  • 2016年最值得學(xué)習(xí)的五大開源項(xiàng)目

    摘要:是學(xué)習(xí)動(dòng)畫很好的項(xiàng)目,項(xiàng)目代碼量比較少,也很適合新手學(xué)習(xí)。遵循了谷歌材料設(shè)計(jì),加入了一些以上的新特性,閱讀體驗(yàn)絕不遜色于官方的。架構(gòu)項(xiàng)目地址由谷歌工程師開發(fā),展示的材料設(shè)計(jì),項(xiàng)目代碼量大,但是結(jié)構(gòu)清晰,還是很好理解的。 1.Material Animations 演示View的平移、縮放動(dòng)畫,activity進(jìn)入和退出動(dòng)畫,界面間元素共享。是學(xué)習(xí)動(dòng)畫很好的項(xiàng)目,項(xiàng)目代碼量比較少,也很適...

    RichardXG 評(píng)論0 收藏0
  • 3年軟件測(cè)試經(jīng)驗(yàn)突顯迷茫...不知道我這種測(cè)試人員是不是被淘汰???

    這兩天和朋友談到軟件測(cè)試的發(fā)展:這一行的變化確實(shí)蠻大,從開始最基礎(chǔ)的功能測(cè)試,到現(xiàn)在自動(dòng)化、性能、安全乃至于以后可能出現(xiàn)的大數(shù)據(jù)測(cè)試、AI測(cè)試崗位需求逐漸增多。我也在軟件測(cè)試這行摸爬滾打了十年了,正好有朋友問我:如何快速成為互聯(lián)網(wǎng)時(shí)代優(yōu)秀的測(cè)試工程師呢?趁著最近終于有了些閑余時(shí)間,遂總結(jié)了下自動(dòng)化測(cè)試的成長(zhǎng)線路圖和職業(yè)必備技能,希望可以幫助各位少走彎路、破繭成蝶、邁向成功。 下面我來分享下自動(dòng)化測(cè)...

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

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

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<