首頁 >Java >java教程 >有關java多執行緒討論

有關java多執行緒討論

巴扎黑
巴扎黑原創
2017-07-20 13:24:491634瀏覽

一、主題導入

       在開始簡述Java多執行緒機制之前,我必須吐槽一下我國糟糕的IT界技術分享氛圍與不給力的互聯網技術解答深度。當一個初學java的小哥向我請教Java多線程機制相關問題時,我請他去尋求度娘的幫助,讓他先學會自己嘗試解決問題;但是他告訴我在網上找不到他想要的訊息,我也嘗試性的在網路上收刮了半天,也確實找不到內容詳盡、表達清晰的文獻。更遺憾的是某些也許有一定參考價值的文檔都需要透過非正常手段下載,例如註冊、回覆甚至是花錢購買,這難免會讓不少人望而卻步,最後不了了之。

       我並不是蓄意抨擊,而是希望更多的人能夠向Linux自由之父Stallman一樣,學會奉獻;如果大家都能夠嘗試去奉獻,最終每個人也將更易於索取。

       (以後得空將會陸續將Java各知識點歸類總結,並放在CSDN個人部落格中;出Java之外還考慮介紹下其他方面的內容,屆時請保持關注喲^(  。。)^)


二、現實中的類似問題

##       假設你是某快餐店的老闆,隨著自己的苦心經營,終於讓快餐店門庭若市、生意興隆;為了拓展銷路,你決定增加送餐上門服務,公司財務告訴你你可以為拓展此業務支配12萬元,這時候你會怎麼支配這筆錢?

       當然有許多支配方式,並且在支配上需要考慮到人員數量、送餐範圍、送餐形式等多個問題;這裡我們集中討論下送餐形式這個細節:

       1)買一輛雪弗蘭賽歐;

       2)買15輛電瓶車;

       除去員工薪資等基本成本過後剩餘的錢用於購買送餐工具,上面我給了兩種送餐交通工具,他們都有各自的優點:首先,雪佛蘭賽歐能夠達到更快的送餐速度,而且可以供應的送餐範圍更廣;其次,用電瓶車作為送餐交通工具可以同時為多個顧客派送,並且運送成本顯然更加低廉。在這兩者之間,你會作何選擇?

       明顯是第二種送餐交通工具較為實用:相較之下,後者可以處理的顧客數量較多,靠後的顧客等待時間明顯縮短。試想一下,如果你打了電話定了午飯,就因為你是第25個顧客,晚上六點才給你送來,你會是什麼心情?

       其實,速食店老闆選擇多輛電瓶車送餐的考慮同進程選擇多執行緒控制的思想是如出一轍的,單線的程式往往功能非常有限,在某些特定領域甚至無法達到我們所期望的效能。例如,當你想讓伺服器資料能夠被多個客戶同時存取時,單線程將讓這一設想化為泡影;單線程情況下,多個客戶的需求將存入一個棧隊,並且依次執行,靠後的客戶很難有較好的訪問體驗。

       Java語言提供了非常優秀的多執行緒支持,多執行緒的程式可以包含多個順序執行流,且多個順序執行流之間互不干擾。總的來說,使用多執行緒程式設計有以下多個優點:

       1)多個執行緒之間可以共享記憶體資料;

################################################# #       2)多個執行緒是並發執行的,可以同時完成多個任務;######

       3)Java語言內建了多執行緒功能支持,從而簡化了Java的多執行緒程式設計。

多執行緒的建立方式

(1)繼承Thread類別:這種方式一般不常用,考慮到新建的執行緒類別有繼承其他父類別的需要;

 MyThread

(2)實作Runnable介面:最常用的方式

class MyThread implements Runnable{
  @Overridepublic void run(){      //do something here             }
}

(3)實作Callable介面:這種方式用於需要傳回結果值的場景下,實作Collable介面需要實作其call()方法

 class MyThread implements Callable<String>{
  @Override
  public String call() throws Exception{
     //do something here
    return XXX;
  }
  
}

public class FutureMain{
  public static void main(String[] args){
    //构造FutureTask
    FutureTask<String> future = new FutureTask<String>(new MyThread());
    Thread t1 = new Thread(future);
    t1.start();
    //取得call()方法的返回值
    System.out.println("返回值"+future.get());
  }
}

#當然,除了基本的功能外,JDK也為Future提供了一些簡單的控制功能:

boolean cancle(boolean mayInterruptIfRunning);                       //取消任务boolean isCancelled();                                               //是否已经取消boolean isDone();                                                    //是否已完成

 

以上是有關java多執行緒討論的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn