中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中有哪些實現多線程的方法

發布時間:2021-04-22 17:41:30 來源:億速云 閱讀:142 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關java中有哪些實現多線程的方法,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

常用的java框架有哪些

1.SpringMVC,Spring Web MVC是一種基于Java的實現了Web MVC設計模式的請求驅動類型的輕量級Web框架。2.Shiro,Apache Shiro是Java的一個安全框架。3.Mybatis,MyBatis 是支持普通 SQL查詢,存儲過程和高級映射的優秀持久層框架。4.Dubbo,Dubbo是一個分布式服務框架。5.Maven,Maven是個項目管理和構建自動化工具。6.RabbitMQ,RabbitMQ是用Erlang實現的一個高并發高可靠AMQP消息隊列服務器。7.Ehcache,EhCache 是一個純Java的進程內緩存框架。

1、lambda表達式創建線程

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

package com.kingh.thread.create;

public class CreateThreadDemo5_Lambda {
 
    public static void main(String[] args) throws Exception {
        // 使用lambda的形式實例化線程任務類
        Runnable task = () -> {
            while (true) {
                // 輸出線程的名字
                printThreadInfo();
            }
        };
 
        // 創建線程對象,并將線程任務類作為構造方法參數傳入
        new Thread(task).start();
 
        // 主線程的任務,為了演示多個線程一起執行
        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接口。執行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;
   // 創建一個線程池
   ExecutorService pool = Executors.newFixedThreadPool(taskSize);
   // 創建多個有返回值的任務
   List<Future> list = new ArrayList<Future>();
   for (int i = 0; i < taskSize; i++) {
    Callable c = new MyCallable(i + " ");
    // 執行任務并獲取Future對象
    Future f = pool.submit(c);
    // System.out.println(">>>" + f.get().toString());
    list.add(f);
   }
   // 關閉線程池
   pool.shutdown();
 
   // 獲取所有并發任務的運行結果
   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<Object> {
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中有哪些實現多線程的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩留县| 太白县| 漯河市| 岳池县| 定襄县| 嘉黎县| 察雅县| 凤凰县| 桓台县| 平乡县| 错那县| 宿州市| 乌鲁木齐县| 马龙县| 文登市| 拜城县| 五华县| 武功县| 鹤岗市| 怀集县| 黔西| 全南县| 钦州市| 收藏| 湖州市| 云安县| 云阳县| 延安市| 海南省| 涟源市| 岳阳市| 郁南县| 富阳市| 伊春市| 安龙县| 韶关市| 依兰县| 东乡族自治县| 基隆市| 仲巴县| 罗源县|