亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java之Runnable啟動(dòng)線程的使用方式

 更新時(shí)間:2024年01月16日 10:12:02   作者:.二丫.  
這篇文章主要介紹了Java之Runnable啟動(dòng)線程的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Runnable啟動(dòng)線程的使用

實(shí)現(xiàn)線程的方式

Runnable接口

  • Runnable 接口的實(shí)現(xiàn)類的線程 通過(guò)Thread類啟動(dòng)
  • 需要把實(shí)現(xiàn)類對(duì)象傳入Thread類的構(gòu)造方法中 然后通過(guò)Thread的start方法啟動(dòng)該Runnable實(shí)現(xiàn)類的線程。
  • Runnable實(shí)現(xiàn)類線程 只需要?jiǎng)?chuàng)建一個(gè)對(duì)象 然后傳入多個(gè)Thread類構(gòu)造方法中,通過(guò)多個(gè)Thread對(duì)象去啟動(dòng)多個(gè)線程。

Runnable接口的優(yōu)點(diǎn)

  • 可以避免由于Java單繼承帶來(lái)的局限性(不占繼承名額)
  • 適合多個(gè)相同程序的代碼去處理同一個(gè)資源的情況
  • 把線程同程序的代碼,數(shù)據(jù)有效分離,較好的體現(xiàn)了面向?qū)ο蟮脑O(shè)計(jì)思想。

Demo.java 文件

public class Demo {

    public static void main(String[] args) {
//        MyThread m1 = new MyThread("張三");
//        MyThread m2 = new MyThread("李四");
//
//        m1.start();
//        m2.start();

        MyRunnable1 m = new MyRunnable1();
        Thread t1 = new Thread(m,"張三");
        Thread t2 = new Thread(m,"李四");

        t1.start();
        t2.start();


    }
    public static void main1(String[] args) {
        //MyRunnable myRunnable = new MyRunnable("張三");//這種給線程命名的方式不可行
        MyRunnable myRunnable = new MyRunnable();

//        Thread t1 = new Thread(myRunnable);//將Runnable類對(duì)象傳入Thread類對(duì)象的構(gòu)造方法中
//        Thread t2 = new Thread(myRunnable);

        Thread t1 = new Thread(myRunnable,"張三");//通過(guò)Thread方法來(lái)設(shè)置自己線程的名字
        Thread t2 = new Thread(myRunnable,"李四");

        t1.start();
        t2.start();

    }
}

MyThread.java 文件

public class MyThread extends Thread {
    public MyThread(){

    }

    public MyThread(String name){
        super(name);
    }

    //int num = 50;//減少的時(shí)候是張三和李四分別減少50
    public static int num = 50;//減少的時(shí)候是張三和李四共同減少50一個(gè)數(shù)字

    @Override
    public void run() {
        while(num > 0 ){
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+":正在減---->"+(num--));
        }
    }
}

MyRunnable.java文件

public class MyRunnable implements Runnable {
    public MyRunnable() {

    }

    public MyRunnable(String name){//我們自己寫的 有參數(shù)的構(gòu)造器 但是無(wú)法給我們的線程重新命名
        //Thread.currentThread().setName(name);
        //System.out.println(Thread.currentThread().getName());//這句代碼是主線程執(zhí)行的所以無(wú)法給子線程改名字
    }

    @Override
    public void run() {
        for (int i = 0; i < 50; i++) {
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"正在數(shù)--->"+i);
        }
    }
}

MyRunnable1.java文件

public class MyRunnable1 implements Runnable {

    public int num = 50;//不需要加static

    @Override
    public void run() {
        while(num > 0){
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"--->正在減"+(num--));
        }
    }
}

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java代碼是如何被CPU狂飆起來(lái)的

    Java代碼是如何被CPU狂飆起來(lái)的

    無(wú)論是剛剛?cè)腴TJava的新手還是已經(jīng)工作了的老司機(jī),恐怕都不容易把Java代碼如何一步步被CPU執(zhí)行起來(lái)這個(gè)問(wèn)題完全講清楚。本文就帶你詳細(xì)了解Java代碼到底是怎么運(yùn)行起來(lái)的。感興趣的同學(xué)可以參考閱讀
    2023-03-03
  • Java中特殊運(yùn)算符及其應(yīng)用詳解

    Java中特殊運(yùn)算符及其應(yīng)用詳解

    當(dāng)涉及位操作和位級(jí)運(yùn)算時(shí),Java?提供了一組特殊的運(yùn)算符,即左移(<<)和右移(>>)運(yùn)算符,下面小編就帶大家深入了解一下它們的具體應(yīng)用吧
    2023-08-08
  • java實(shí)現(xiàn)停車場(chǎng)系統(tǒng)

    java實(shí)現(xiàn)停車場(chǎng)系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)停車場(chǎng)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • spring cloud consul注冊(cè)的服務(wù)報(bào)錯(cuò)critical的解決

    spring cloud consul注冊(cè)的服務(wù)報(bào)錯(cuò)critical的解決

    這篇文章主要介紹了spring cloud consul注冊(cè)的服務(wù)報(bào)錯(cuò)critical的解決,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • springboot filter實(shí)現(xiàn)請(qǐng)求響應(yīng)全鏈路攔截

    springboot filter實(shí)現(xiàn)請(qǐng)求響應(yīng)全鏈路攔截

    這篇文章主要為大家詳細(xì)介紹了SpringBoot如何結(jié)合Filter同時(shí)攔截請(qǐng)求和響應(yīng),從而實(shí)現(xiàn)??日志采集自動(dòng)化,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-04-04
  • 基于Java中對(duì)域和靜態(tài)方法的訪問(wèn)不具有多態(tài)性(實(shí)例講解)

    基于Java中對(duì)域和靜態(tài)方法的訪問(wèn)不具有多態(tài)性(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇基于Java中對(duì)域和靜態(tài)方法的訪問(wèn)不具有多態(tài)性(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • 最新JVM垃圾回收算法詳解

    最新JVM垃圾回收算法詳解

    ? 垃圾收集器對(duì)堆進(jìn)行回收前,首先要確定堆中的對(duì)象哪些還"存活",哪些已經(jīng)"死去"。有兩種算法,分別是引用計(jì)數(shù)算法(Recference?Counting)和可達(dá)性分析算法(Reachability?Analysis),這篇文章主要介紹了JVM垃圾回收算法,需要的朋友可以參考下
    2022-05-05
  • Java向上轉(zhuǎn)型與向下轉(zhuǎn)型超詳細(xì)圖解

    Java向上轉(zhuǎn)型與向下轉(zhuǎn)型超詳細(xì)圖解

    我們?cè)贘ava編程中經(jīng)常碰到類型轉(zhuǎn)換,對(duì)象類型轉(zhuǎn)換主要包括向上轉(zhuǎn)型和向下轉(zhuǎn)型,這篇文章主要介紹了Java向上轉(zhuǎn)型與向下轉(zhuǎn)型的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-04-04
  • java如何測(cè)試網(wǎng)絡(luò)連通性

    java如何測(cè)試網(wǎng)絡(luò)連通性

    這篇文章主要為大家詳細(xì)介紹了java測(cè)試網(wǎng)絡(luò)連通性的兩種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • springboot循環(huán)依賴問(wèn)題案例代碼及解決辦法

    springboot循環(huán)依賴問(wèn)題案例代碼及解決辦法

    在 Spring Boot 中,如果兩個(gè)或多個(gè) Bean之間存在循環(huán)依賴(即 Bean A 依賴 Bean B,而 Bean B 又依賴 Bean A),會(huì)導(dǎo)致 Spring 的依賴注入機(jī)制無(wú)法正確處理,從而拋出異常,下面給大家介紹springboot循環(huán)依賴問(wèn)題及其解決辦法,感興趣的朋友一起看看吧
    2025-04-04

最新評(píng)論