最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯網營銷解決方案
java的多線程如何實現

本篇內容介紹了“java的多線程如何實現”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

創(chuàng)新互聯建站是一家企業(yè)級云計算解決方案提供商,超15年IDC數據中心運營經驗。主營GPU顯卡服務器,站群服務器,南充服務器托管,海外高防服務器,機柜大帶寬租用·托管,動態(tài)撥號VPS,海外云手機,海外云服務器,海外服務器租用托管等。

1、lambda表達式創(chuàng)建線程

使用lambda的形式實例化線程任務類,創(chuàng)建線程對象,并將線程任務類作為構造方法參數傳入。

package com.kingh.thread.create;
 
/**
 * 創(chuàng)建線程with lambda
 *
 * @author Kingh
 * @version 1.0
 * @date 2019/3/18 10:04
 */
public class CreateThreadDemo5_Lambda {
 
    public static void main(String[] args) throws Exception {
        // 使用lambda的形式實例化線程任務類
        Runnable task = () -> {
            while (true) {
                // 輸出線程的名字
                printThreadInfo();
            }
        };
 
        // 創(chuàng)建線程對象,并將線程任務類作為構造方法參數傳入
        new Thread(task).start();
 
        // 主線程的任務,為了演示多個線程一起執(zhí)行
        while (true) {
            printThreadInfo();
            Thread.sleep(1000);
        }
    }
 
    /**
     * 輸出當前線程的信息
     */
    private static void printThreadInfo() {
        System.out.println("當前運行的線程名為: " + Thread.currentThread().getName());
        try {
            Thread.sleep(1000);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

2、使用ExecutorService、Callable、Future實現有返回結果的多線程

可以返回值的任務必須是Callable接口,類似的,沒有返回值的任務必須是Runnable接口。執(zhí)行Callable任務后,可以獲得一個Future對象,通過調用get可以獲得Callable任務返回的Object,然后結合線程池接口ExecutorService可以實現傳說中有返回結果的多線程。

import java.util.concurrent.*;
import java.util.Date;
import java.util.List;
import java.util.ArrayList;
 
/**
* 有返回值的線程
*/
@SuppressWarnings("unchecked")
public class Test {
public static void main(String[] args) throws ExecutionException,
    InterruptedException {
   System.out.println("----程序開始運行----");
   Date date1 = new Date();
 
   int taskSize = 5;
   // 創(chuàng)建一個線程池
   ExecutorService pool = Executors.newFixedThreadPool(taskSize);
   // 創(chuàng)建多個有返回值的任務
   List list = new ArrayList();
   for (int i = 0; i < taskSize; i++) {
    Callable c = new MyCallable(i + " ");
    // 執(zhí)行任務并獲取Future對象
    Future f = pool.submit(c);
    // System.out.println(">>>" + f.get().toString());
    list.add(f);
   }
   // 關閉線程池
   pool.shutdown();
 
   // 獲取所有并發(fā)任務的運行結果
   for (Future f : list) {
    // 從Future對象上獲取任務的返回值,并輸出到控制臺
    System.out.println(">>>" + f.get().toString());
   }
 
   Date date2 = new Date();
   System.out.println("----程序結束運行----,程序運行時間【"
     + (date2.getTime() - date1.getTime()) + "毫秒】");
}
}
 
class MyCallable implements Callable {
private String taskNum;
 
MyCallable(String taskNum) {
   this.taskNum = taskNum;
}
 
public Object call() throws Exception {
   System.out.println(">>>" + taskNum + "任務啟動");
   Date dateTmp1 = new Date();
   Thread.sleep(1000);
   Date dateTmp2 = new Date();
   long time = dateTmp2.getTime() - dateTmp1.getTime();
   System.out.println(">>>" + taskNum + "任務終止");
   return taskNum + "任務返回運行結果,當前任務時間【" + time + "毫秒】";
}
}

“java的多線程如何實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯網站,小編將為大家輸出更多高質量的實用文章!


網站名稱:java的多線程如何實現
轉載來源:http://fisionsoft.com.cn/article/ijgiep.html