線程創建

来源:https://www.cnblogs.com/ShaPii/archive/2023/07/09/17538741.html
-Advertisement-
Play Games

### 三種創建方式 - Thread class 繼承Thread類 - Runnable介面 實現Runnable介面 - Callable介面 實現Callable介面 ### Thread - 自定義線程類繼承Thread類 - 重寫run()方法,編寫線程執行體 - 創建線程對象,調用st ...


三種創建方式

  • Thread class 繼承Thread類
  • Runnable介面 實現Runnable介面
  • Callable介面 實現Callable介面

Thread

  • 自定義線程類繼承Thread類

  • 重寫run()方法,編寫線程執行體

  • 創建線程對象,調用start()方法啟動線程

    //創建線程方式一:繼承Thread類,重寫run()方法,調用start開啟線程
    //註意,線程開啟不一定立即執行,由cpu調度執行
    public class TestThread extends Thread{
    
        @Override
        public void run() {
            //run方法線程體
            for (int i = 0; i < 20; i++) {
                System.out.println("我在Run方法"+i);
            }
        }
    
        public static void main(String[] args) {
            //main線程,主線程
            //創建一個線程對象
            TestThread testThread=new TestThread();
    
            //調用start()方法開啟線程
            testThread.start();
    
            for (int i = 0; i < 20; i++) {
                System.out.println("我在main函數中"+i);
            }
        }
    }
    

    註:run方法只是普通方法,直接調用程式只是先後分別執行兩個方法,而start方法,相當於另外開闢一個子線程,去執行run方法,也就是實現兩個方法同時進行;

    編譯部分結果:(每次結果都可能不一樣)

    我在main函數中0
    我在Run方法0
    我在main函數中1
    我在Run方法1
    我在main函數中2
    我在Run方法2
    我在main函數中3
    我在Run方法3
    我在Run方法4
    我在Run方法5
    我在Run方法6
    我在main函數中4
    我在Run方法7
    我在main函數中5
    我在main函數中6
    我在Run方法8
    ...........
    

實現Runable

  • 定義MyRunnable類實現Runnable介面
  • 實現run()方法,編寫線程執行體
  • 創建線程對象,調用start()方法啟動線程
//實現線程方式2:實現runnable介面,重寫run方法,執行線程需要丟入runnable介面實現類,調用start方法
public class TestThread2 implements Runnable{

    @Override
    public void run() {
        //run方法線程體
        for (int i = 0; i < 20; i++) {
            System.out.println("我在Run方法"+i);
        }
    }

    public static void main(String[] args) {
        //main線程,主線程

        //創建runnable介面的實現類對象
        TestThread2 testThread2=new TestThread2();

        //創建線程對象,通過線程對象來開啟我們的線程,代理
//        Thread thread=new Thread(testThread2);
//        thread.start();
        new Thread(testThread2).start();

        for (int i = 0; i < 20; i++) {
            System.out.println("我在main函數中"+i);
        }
    }
}

編譯部分結果:(每次結果都可能不一樣)

我在main函數中0
我在Run方法0
我在main函數中1
我在Run方法1
我在main函數中2
我在Run方法2
我在main函數中3
我在Run方法3
我在Run方法4
我在main函數中4
........

小結

繼承thread

  • 子類繼承Thread類具備多線程能力
  • 啟動線程:子類對象.start()
  • 不建議使用:避免OOP單繼承

實現Runnable介面

  • 實現介面Runnable具備多線程能力
  • 啟動線程:傳入目標對象+Thread對象.start()
  • 推薦使用:避免單繼承局限性,靈活性,方便同一個對象被多個線程使用

實現Callable介面

  1. 實現Callable介面,需要返回值類型
  2. 重寫call方法,需要拋出異常
  3. 創建目標對象
  4. 創建執行服務:ExecutorService ser=Executors.newFixedThreadPool(1);
  5. 提交執行:Future result1=ser.submit(t1);
  6. 獲取執行:boolean r1=result1.get();
  7. 關閉服務:ser.shutdownNow();
//線程創建方式三:實現callable介面
/*
callabel的好處
1,可以定義返回值
2,可以拋出異常
 */
public class CallableTest implements Callable<Boolean> {
        private String url;//下載網路圖片地址
        private String name; //保存的文件名

    public CallableTest(String url, String name) {
        this.name = name;
        this.url = url;
    }

        //下載圖片線程的執行體
        public Boolean call() {
        WebDownLoder webDownLoder = new WebDownLoder();
        webDownLoder.downLoader(url, name);
        System.out.println("下載好文件" + name);
        return true;
    }

        public static void main(String[] args) throws ExecutionException, InterruptedException {
            CallableTest t1=new CallableTest("https://img0.baidu.com/it/u=1435639120,2241364006&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=500","1.jpg");
            CallableTest t2=new CallableTest("https://img1.baidu.com/it/u=2559867097,3726275945&fm=253&fmt=auto&app=138&f=JPEG?w=1333&h=500","2.jpg");
            CallableTest t3=new CallableTest("https://img0.baidu.com/it/u=2503372846,402736698&fm=253&fmt=auto&app=120&f=JPEG?w=1280&h=800","3.jpg");

            //1. 創建執行服務:
            ExecutorService ser= Executors.newFixedThreadPool(3);
            //2. 提交執行:
            Future<Boolean> r1=ser.submit(t1);
            Future<Boolean> r2=ser.submit(t2);
            Future<Boolean> r3=ser.submit(t3);
            //3. 獲取執行:
            boolean rs1=r1.get();
            boolean rs2=r2.get();
            boolean rs3=r3.get();
            //4. 關閉服務:
            ser.shutdownNow();
    }
}
//下載器
class WebDownLoder{
    //下載方法
    public void downLoader(String url, String name) {
        try {
            FileUtils.copyURLToFile(new URL(url), new File(name));
        } catch (IOException e) {
            e.printStackTrace();
            System.out.println("IO異常,downLoader方法出現問題");
        }
    }
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 大家好,我是 god23bin,今天繼續說 Spring 的內容,關於 Spring 中 Bean 的配置的,通過上一篇文章的學習,我們知道了 Spring 中的依賴註入,其中有兩種主要的方式,分別是基於構造方法的 DI 和 基於 Setter 的 DI。 ...
  • > 最近燒哥發現個寶藏項目,竟然用Java開發了暗黑2出來。 眾所周知,暗黑2是暴雪開發的一款經典游戲,距今雖有20多年,仍然有很多粉絲。 粉絲延續熱情的方式有很多,一種是做Mod,比如[魔電](https://www.median-xl.com/),對怪物、技能、物品、場景、甚至游戲機制都有大改, ...
  • # Qt deleteLater作用及源碼分析 > 個人經驗總結,如有錯誤或遺漏,歡迎各位大佬指正 🥳 在本篇文章中,我們將深入分析源碼,探討`deleteLater`的原理。 `deleteLater`是Qt框架提供的一個重要函數,用於在事件迴圈中延遲刪除對象。 在軟體開發中,延遲刪除對象的概念 ...
  • 如果模板里需要用變數填充表格,建議模板里的表格像word文件一樣建一個兩行的表格。但是這樣是freemaker是無法成功替換變數的,所以需要手動處理成到一個段里(如圖2),關於這點實在太無語了,因為沒有找到比較好的處理辦法,只能手工處理,在實際的開發工作中曾經花了幾個小時來做這件事情。根據模板文件生... ...
  • 一. 介紹 String、StringBuffer、StringBuilder: 前言: String、StringBuffer、StringBuilder 均在java.lang包下; String: 在Java中,String是一個特殊的引用類型,用於表示文本字元串。它提供了許多方法來操作和處理 ...
  • ## **Docker是什麼?** Docker是一個開源平臺,通過將應用程式隔離到輕量級、可移植的容器中,自動化應用程式的部署、擴展和管理。容器是獨立的可執行單元,封裝了運行應用程式所需的所有必要依賴項、庫和配置文件,可以在各種環境中穩定地運行。 # **什麼是容器?** 容器是一種輕量級、可移植 ...
  • - 背景: 經常創建和銷毀,使用量特別大的資源,比如併發情況下的線程,對性能影響很大。 - 思路:提前創建好多個線程,放入線程池中,使用時直接獲取,使用完放後池中。可以避免頻繁創建銷毀,實現重覆利用。類似生活中公共交通工具。 - 好處: - 提高響應速度(減少了創建新線程的時間) - 降低資源消耗( ...
  • **本文深入探討了 Django 中的請求與響應處理,從 Django 請求和響應的基礎知識、生命周期,到 HttpRequest 和 HttpResponse 對象的詳細介紹。同時,討論了 Django 的視圖和請求、響應處理,以及安全性和非同步處理的考慮。最後,對比了 Django 與 Flask ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...