Thread t1 = new Thread(mr) 原理

核心原理

1. Thread构造方法的重载

Thread类有多个构造方法,其中一个是:

java 复制代码
public Thread(Runnable target) {
    // 将Runnable对象保存到Thread的target字段
    this.target = target;
}

2. Thread的run方法实现

Thread类的run方法是这样实现的:

java 复制代码
@Override
public void run() {
    if (target != null) {
        target.run();  // 调用传入的Runnable对象的run方法
    }
}

详细执行流程

步骤1:创建Runnable对象

java 复制代码
Myrun mr = new Myrun();
  • 创建了一个实现了Runnable接口的对象
  • 这个对象有run方法的具体实现

步骤2:创建Thread对象

java 复制代码
Thread t1 = new Thread(mr);
  • 调用Thread(Runnable target)构造方法
  • 将mr对象保存到Thread的target字段中

步骤3:启动线程

java 复制代码
t1.start();
  • 启动线程t1
  • 线程开始执行run方法

步骤4:执行run方法

java 复制代码
// Thread的run方法内部
if (target != null) {
    target.run();  // 调用mr.run()
}

代码结构分析

Thread类的内部结构

java 复制代码
public class Thread implements Runnable {
    private Runnable target;  // 保存Runnable对象的字段
    
    // 构造方法
    public Thread(Runnable target) {
        this.target = target;
    }
    
    // run方法
    @Override
    public void run() {
        if (target != null) {
            target.run();  // 调用传入对象的run方法
        }
    }
}

实际执行示例

完整流程演示

java 复制代码
public class ThreadDemo {
    public static void main(String[] args) {
        // 1. 创建任务对象
        Myrun mr = new Myrun();
        
        // 2. 创建线程对象,传入任务
        Thread t1 = new Thread(mr);
        Thread t2 = new Thread(mr);
        
        // 3. 启动线程
        t1.start();
        t2.start();
    }
}

class Myrun implements Runnable {
    @Override
    public void run() {
        for (int i = 0; i < 5; i++) {
            System.out.println(Thread.currentThread().getName() + " 执行第" + i + "次");
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

执行结果

java 复制代码
Thread-0 执行第0次
Thread-1 执行第0次
Thread-0 执行第1次
Thread-1 执行第1次
...

总结

Thread t1 = new Thread(mr) 的原理是:

  1. 构造方法:Thread(Runnable target)将mr保存到target字段
  1. run方法:Thread的run方法调用target.run()
  1. 任务执行:实际执行的是mr.run()方法
  1. 设计模式:使用组合模式,Thread管理线程,Runnable定义任务

这种设计让线程管理和任务逻辑分离,提高了代码的灵活性和可维护性!

相关推荐
橙淮3 小时前
并发编程(六)
java·jvm
EntyIU4 小时前
JVM内存与GC笔记
java·jvm·笔记
雪宫街道4 小时前
synchronized 锁的范围:对象锁、类锁与代码块锁
java·jvm·后端·面试
小江的记录本7 小时前
【JVM虚拟机】JVM调优:常用JVM参数、调优核心指标、OOM排查、GC日志分析、Arthas工具使用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
小江的记录本12 小时前
【JVM虚拟机】类加载机制:类加载全流程:加载→验证→准备→解析→初始化(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·算法·安全·spring·面试
jameslogo15 小时前
类加载机制
jvm
雪度娃娃17 小时前
转向现代C++——优先选用删除函数而非private未定义函数
java·jvm·c++
努力发光的程序员17 小时前
面试官与程序员谢飞机的3轮Java大厂面试问答实录:涵盖Spring Boot、微服务与数据库技术
java·jvm·spring boot·redis·面试·hibernate·microservices
橙淮17 小时前
并发编程(四)
java·jvm
Python+9918 小时前
C++ 内存模型 & 底层原理
java·jvm·c++