1.3currentThread()方法

currentThread()方法可以返回段正在被哪个线程调用的信息。

示例代码:

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

结果:说明main()被名为main的线程调用。

示例代码:

public class OneThread extends Thread {
    public OneThread() {
        System.out.println("构造方法的打印: " + Thread.currentThread().getName());
    }

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

 执行方法:

public class Main {
    public static void main(String[] args) {
        OneThread ot = new OneThread();
        ot.start();
    }
}

结果:

若执行方法为:

public class Main {
    public static void main(String[] args) {
        OneThread ot = new OneThread();
        ot.run();//注意此处调用的是run(),我们曾提过,调用run()相当于将run()交给其他线程来完成
    }
}

结果:

更复杂的示例:

public class TwoThread extends Thread {
    public TwoThread() {
        System.out.println("Count-Operate--begin");
        System.out.println("Thread.currentThread().getName()= " + Thread.currentThread().getName());
        System.out.println("this.getName()= " + this.getName());
        System.out.println("Count-Operate--end");
    }

    @Override
    public void run() {
        System.out.println("run--begin");
        System.out.println("Thread.currentThread().getName()=" + Thread.currentThread().getName());
        System.out.println("this.getName()= " + this.getName());
        System.out.println("run--end");
    }
}

 执行代码:

public class Main {
    public static void main(String[] args) {
        TwoThread tt = new TwoThread();
        Thread t = new Thread(tt);
        t.setName("A");
        t.start();
    }
}

 结果:

根据结果逆向分析:Thread.currentThread().getName()获得的始终是主线程(也就是说由JVM创建的main线程)。

而由对象本身调用的getName()获取的都是打开的第二个线程Thread-0,也就是执行start()方法的线程。

现在分析发现这个思考是有问题的。

Thread.currentThread().getName()获得的始终是执行start()方法的线程(或者说是调用run()方法的线程)。

而this.getName()获得的都是run()方法所在线程对象的名称。

源码地址:https://github.com/lilinzhiyu/threadLearning

如果有错误欢迎各位指出。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏向治洪

传统多线程之前如何共享数据

几种方式 线程执行代码相同,使用同一Runnable对象,Runnable对象中有共享数据 线程执行代码不同,将共享数据封装在另一对象中(操作数据的方法也在该...

17710
来自专栏青枫的专栏

java基础学习_多线程01_多线程_day23总结

582
来自专栏java一日一条

Java 并发开发:内置锁 Synchronized

在多线程编程中,线程安全问题是一个最为关键的问题,其核心概念就在于正确性,即当多个线程访问某一共享、可变数据时,始终都不会导致数据破坏以及其他不该出现的结果。而...

402
来自专栏互联网开发者交流社区

java 多线程学习

812
来自专栏用户3030674的专栏

java线程的实现

一共有两种方法Thread类和Runnable接口,相对来讲,更趋向于用Runnable 因为一个类可以实现多个接口,但是只能继承一个类,所以相对来说倾向用Ru...

521
来自专栏青枫的专栏

关于多线程的几道面试小题

  自定义类中不是所有的代码都需要被线程执行。   而这个时候,为了区分哪些代码能够被线程执行,java提供了Thread类中的run()方法,用来包含那些需要...

421
来自专栏青枫的专栏

多线程常见的面试题

1153
来自专栏青枫的专栏

同步解决线程安全问题的三种实现

561
来自专栏LinkedBear的个人空间

唠唠SE的多线程-02——线程锁 原

        可以使用this关键字作为锁对象,也可以使用所在类的字节码文件对应的Class对象作为锁对象

692
来自专栏小二的折腾日记

多线程

进程:是一个正在执行中的程序。 每一个进程执行都有一个执行顺序。该顺序是一个执行路径,或者叫一个控制单元。 线程:就是进程中的一个独立的控制单元。 线程在控制...

331

扫码关注云+社区