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

Java?Thread.currentThread().getName()?和?this.getName()區(qū)別詳解

 更新時間:2022年02月21日 08:39:42   作者:經(jīng)典雞翅  
本文主要介紹了Thread.currentThread().getName()?和?this.getName()區(qū)別詳解,TestThread?testThread?=?new?TestThread();

currentThread的詳解

currentThread方法是Thread類的一個靜態(tài)方法,用來獲取當(dāng)前運行的代碼段,正在被哪個線程調(diào)用。我們先來看一眼源碼。

是一個native方法。直接與系統(tǒng)層面做交互。
下面看一段代碼

 public static void main(String[] args) {
        String name = Thread.currentThread().getName();
        System.out.println(name);
    }

輸出的結(jié)果為main。

為什么為main呢?

java的項目在啟動的時候,會創(chuàng)立一個進程,這個進程同樣也是一個線程,在java里面他就叫做main線程。他的名字在設(shè)定的時候就是main。我們可以看到上面的代碼就是在main方法下執(zhí)行的,也就是由main線程來執(zhí)行,所以我們打印出來的名字是main。

創(chuàng)建一個新的線程

來看下面的一行代碼,我們創(chuàng)建一個新的線程,并且在線程創(chuàng)建的構(gòu)造方法和其實際執(zhí)行的run方法內(nèi),增加打印出當(dāng)前執(zhí)行線程的名稱。

public class TestThread extends Thread {

    public TestThread() {
        System.out.println("構(gòu)造方法:" + Thread.currentThread().getName());
    }

    @Override
    public void run() {
        System.out.println("run方法:" + Thread.currentThread().getName());
    }

    public static void main(String[] args) {
        TestThread testThread = new TestThread();
        testThread.start();
    }

}

我們運行一下,看到結(jié)果

構(gòu)造方法:main
run方法:Thread-0

如何理解上述的情況呢?

我們先來看構(gòu)造方法這一行。

TestThread testThread = new TestThread();

這里我們只是聲明了一個線程對象類,這個新的線程沒有創(chuàng)建也沒有啟動,我們僅僅把它理解為一個普通對象即可。那么由于是在main方法里面,那么執(zhí)行他的一定是main線程,所以可以看到構(gòu)造方法輸出的結(jié)果是main。
再來看start方法里面,為什么變成了thread-0了呢。
我們知道java的多線程創(chuàng)建的一種方式就是繼承thread類。然后實現(xiàn)里面的run方法。這樣當(dāng)線程start的時候,就會調(diào)用內(nèi)部的start0的本地方法,實際就是會執(zhí)行run的實現(xiàn)方法。當(dāng)run方法執(zhí)行的時候,一定是由我們創(chuàng)建的線程去執(zhí)行的,而不是main線程,所以我們就可以得知打印出來的是新線程的名字thread0。

為什么新線程的名字為thread0呢?

我們是采用繼承thread類的形式來創(chuàng)建線程的,那么在我們構(gòu)造的時候,一定會執(zhí)行父類的構(gòu)造方法。我們是一個空參構(gòu)造,那么我們就要看下父類的空參構(gòu)造是什么樣的??匆幌略创a

可以看到,里面有一個name參數(shù),已經(jīng)給我們拼接了一個thread-后面是加了一個變量,我們繼續(xù)看看這個變量是什么

一個同步的靜態(tài)方法,再來看看變量的值。

一個靜態(tài)的int型變量,由此我們知道int的初始值就是0。我們先獲取到了0然后又執(zhí)行了++。其他線程再次初始化的時候就是從1開始了。因為加了同步鎖的關(guān)鍵字,我們不用害怕數(shù)據(jù)會亂掉。
所以我們就知道了新線程的名字為thread-0的來源。

再看一種帶this的情況

public class TestThread extends Thread {

    public TestThread() {
        System.out.println("構(gòu)造方法開始!");
        System.out.println("構(gòu)造方法:" + Thread.currentThread().getName());
        System.out.println("構(gòu)造方法的this名稱:" + this.getName());
        System.out.println("構(gòu)造方法結(jié)束!");
    }

    @Override
    public void run() {
        System.out.println("run方法開始!");
        System.out.println("run方法:" + Thread.currentThread().getName());
        System.out.println("run方法的this名稱:" + this.getName());
        System.out.println("run方法結(jié)束!");
    }

    public static void main(String[] args) {
        TestThread testThread = new TestThread();
        testThread.start();
    }

}

執(zhí)行的結(jié)果如下:

構(gòu)造方法開始!
構(gòu)造方法:main
構(gòu)造方法的this名稱:Thread-0
構(gòu)造方法結(jié)束!
run方法開始!
run方法:Thread-0
run方法的this名稱:Thread-0
run方法結(jié)束!

我們發(fā)現(xiàn)構(gòu)造的this名稱 為thread-0。這個不難理解,this指的是當(dāng)前對象的名稱。因為我們的線程在初始化的時候有了name,所以是thread-0。

創(chuàng)建的線程setName的情況

public class TestThread extends Thread {

    public TestThread() {
        System.out.println("構(gòu)造方法開始!");
        System.out.println("構(gòu)造方法:" + Thread.currentThread().getName());
        System.out.println("構(gòu)造方法的this名稱:" + this.getName());
        System.out.println("構(gòu)造方法結(jié)束!");
    }

    @Override
    public void run() {
        System.out.println("run方法開始!");
        System.out.println("run方法:" + Thread.currentThread().getName());
        System.out.println("run方法的this名稱:" + this.getName());
        System.out.println("run方法結(jié)束!");
    }

    public static void main(String[] args) {
        TestThread testThread = new TestThread();
        testThread.setName("test");
        testThread.start();
    }

}

看一下執(zhí)行的結(jié)果

構(gòu)造方法開始!
構(gòu)造方法:main
構(gòu)造方法的this名稱:Thread-0
構(gòu)造方法結(jié)束!
run方法開始!
run方法:test
run方法的this名稱:test
run方法結(jié)束!

這里有人可能就要問了,為啥構(gòu)造方法的this名稱為thread-0。實際run的時候就變?yōu)閠est了呢。
這是因為我們在構(gòu)造對象的時候,對象還不完整,沒有執(zhí)行到setName這一步。所以二者不一致。

最后看一段復(fù)雜的代碼

public class TestThread extends Thread {

    public TestThread() {
        System.out.println("構(gòu)造方法開始!");
        System.out.println("構(gòu)造方法:" + Thread.currentThread().getName());
        System.out.println("構(gòu)造方法的this名稱:" + this.getName());
        System.out.println("構(gòu)造方法結(jié)束!");
    }

    @Override
    public void run() {
        System.out.println("run方法開始!");
        System.out.println("run方法:" + Thread.currentThread().getName());
        System.out.println("run方法的this名稱:" + this.getName());
        System.out.println("run方法結(jié)束!");
    }

    public static void main(String[] args) {
        TestThread testThread = new TestThread();
        Thread thread = new Thread(testThread);
        System.out.println("新線程thread的名稱:" + thread.getName());
        thread.setName("test");
        thread.start();
    }

}

可以看到如下的結(jié)果

構(gòu)造方法開始!
構(gòu)造方法:main
構(gòu)造方法的this名稱:Thread-0
構(gòu)造方法結(jié)束!
新線程thread的名稱:Thread-1
run方法開始!
run方法:test
run方法的this名稱:Thread-0
run方法結(jié)束!

我們根據(jù)結(jié)果來看,構(gòu)造方法的打印,和上面解釋的如出一轍。我們重點關(guān)注一下新線程的打印,這里為什么是1呢,因為我們上面初始化0之后已經(jīng)++所以為1。
run方法為test是因為我們實際執(zhí)行的線程Thread thread = new Thread(testThread);所以我們獲取到的名稱是thread的名稱為test。
那么run方法的this名稱為什么是thread-0呢。因為this.getName獲取到的是當(dāng)前對象的名稱。我們的當(dāng)前對象是TestThread。他的線程名稱從未被改變過,所以我們拿到了thread-0。

總結(jié)

currentThread的getName代表當(dāng)前執(zhí)行線程的名稱,this.getName代表對象的名稱。this.getName()實際上返回的是target.getName(),而Thread.currentThread().getName()實際上是thead.getName()。

到此這篇關(guān)于Java Thread.currentThread().getName() 和 this.getName()區(qū)別詳解的文章就介紹到這了,更多相關(guān)Thread.currentThread().getName() 和 this.getName()區(qū)別 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • spring boot整合mybatis利用Mysql實現(xiàn)主鍵UUID的方法

    spring boot整合mybatis利用Mysql實現(xiàn)主鍵UUID的方法

    這篇文章主要給大家介紹了關(guān)于spring boot整合mybatis利用Mysql實現(xiàn)主鍵UUID的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • IDEA 中創(chuàng)建SpringBoot 父子模塊的實現(xiàn)

    IDEA 中創(chuàng)建SpringBoot 父子模塊的實現(xiàn)

    這篇文章主要介紹了IDEA 中創(chuàng)建SpringBoot 父子模塊的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 簡單介紹java中equals以及==的用法

    簡單介紹java中equals以及==的用法

    這篇文章主要介紹了簡單介紹java中equals以及==的用法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Spring?Boot?如何正確讀取配置文件屬性

    Spring?Boot?如何正確讀取配置文件屬性

    這篇文章主要介紹了Spring?Boot?如何正確讀取配置文件屬性,項目中經(jīng)常會經(jīng)常讀取配置文件中的屬性的值,Spring?Boot提供了很多注解讀取配置文件屬性,那么如何正確使用呢,下文一起來參考下面文章內(nèi)容吧
    2022-04-04
  • Spring框架核心概念小結(jié)

    Spring框架核心概念小結(jié)

    Spring是企業(yè)級Java的開源開發(fā)框架。Spring框架的核心功能可用于開發(fā)任何java應(yīng)用程序,本文重點給大家介紹Spring框架核心概念總覽,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • MyBatis-Plus聯(lián)表查詢以及分頁代碼實例

    MyBatis-Plus聯(lián)表查詢以及分頁代碼實例

    在開發(fā)中遇到了一個問題,需要進行聯(lián)表查詢并進行分頁,因為不想自己來寫分頁,所以還是依靠MybatisPlus來實現(xiàn)想要的功能,下面這篇文章主要給大家介紹了關(guān)于MyBatis-Plus聯(lián)表查詢以及分頁的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • SpringBoot日志配置操作全面介紹

    SpringBoot日志配置操作全面介紹

    日志,通常不會在需求階段作為一個功能單獨提出來,也不會在產(chǎn)品方案中看到它的細節(jié)。但是,這絲毫不影響它在任何一個系統(tǒng)中的重要的地位,這篇文章主要介紹了SpringBoot日志配置
    2022-10-10
  • SpringBoot返回html界面的使用示例

    SpringBoot返回html界面的使用示例

    本文主要介紹了SpringBoot返回html界面的使用示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • 排查Java應(yīng)用內(nèi)存泄漏問題的步驟

    排查Java應(yīng)用內(nèi)存泄漏問題的步驟

    這篇文章主要介紹了排查Java應(yīng)用內(nèi)存泄漏問題的步驟,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-11-11
  • SSH框架網(wǎng)上商城項目第10戰(zhàn)之搭建商品類基本模塊

    SSH框架網(wǎng)上商城項目第10戰(zhàn)之搭建商品類基本模塊

    這篇文章主要為大家詳細介紹了SSH框架網(wǎng)上商城項目第10戰(zhàn)之搭建商品類基本模塊的相關(guān)資料,有一定的實用性,感興趣的小伙伴們可以參考一下
    2016-06-06

最新評論