Thread继承类中的run()方法和start()方法的区别

本文详细解释了Java中通过Thread类创建线程并启动的方法,对比了直接调用run()方法与使用start()方法的不同之处,并通过实例展示了两者的区别。

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.mythread.www;

import java.util.logging.Level;
import java.util.logging.Logger;

/**
 *
 * @author Administrator
 */
public class Run {
    public static void main(String[] args){
        MyThread thread=new MyThread();
        thread.setName("myThread");
        thread.run();
        for(int i=0;i<10;i++){
            try {
                int time=(int)(Math.random()*1000);
                Thread.sleep(time);
                System.out.println("main="+Thread.currentThread().getName());
            } catch (InterruptedException ex) {
                Logger.getLogger(Run.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
    }
}

      这两者大有讲究。

      在高洪岩先生所著《Java多线程编程核心技术》第6页上,对Thread继承类中的start()和run()方法的区别曾经做过解释:

      Thread.java类中的start()方法通知“线程管理器”(原书是线程规划器,鄙人觉得线程管理器这一称谓更贴切些)此线程已经准备就绪,等待调用线程对象的run()方法。这个过程实际上就是让系统安排一个时间来调用Thread中的run()方法,也就是使线程得到运行,启动线程,具有异步的效果。如果调用代码thread.run()就不是异步执行了,而是同步,那么此对象并不交给“线程处理器”来处理,而是由main主线程来调用run()方法,也就是必须等run()方法中的代码执行完之后才可以执行后面的代码。

package com.mythread.www;

import java.util.logging.Level;
import java.util.logging.Logger;

/**
 *
 * @author Administrator
 */
public class MyThread extends Thread{

    @Override
    public void run(){
        for(int i=0;i<10;i++){
            int time=(int)(Math.random()*1000);
            try {
                Thread.sleep(time);
            } catch (InterruptedException ex) {
                Logger.getLogger(MyThread.class.getName()).log(Level.SEVERE, null, ex);
            }
            System.out.println("run="+Thread.currentThread().getName());
        }
    }
}

 http://blog.youkuaiyun.com/xuxurui007/article/details/7685076

上面链接中的文章是一篇相关文章,希望对大家有所帮助。

### Python3 中 `threading` 模块 `run()` `start()` 方法区别 #### 基本概念 在 Python 的 `threading` 模块中,`Thread` 提供了两个重要的方法:`start()` `run()`。它们的功能用途有所不同。 - **`start()` 方法** 调用 `start()` 方法时,Python 解释器会创建一个新的线程并执行该线程的目标函数。具体来说,当调用 `start()` 后,解释器会在新线程中自动调用 `run()` 方法[^1]。因此,开发者通常不需要直接调用 `run()` 方法,而是通过调用 `start()` 来间接触发它。 - **`run()` 方法** 这是线程的核心逻辑所在,默认情况下,`run()` 是由 `start()` 自动调用的。如果自定义了一个继承自 `Thread` 的子,则可以重写 `run()` 方法来实现特定的任务逻辑[^2]。如果没有显式地提供目标函数(即未设置 `target` 参数),那么线程将默认执行这个 `run()` 方法中的代码。 #### 使用方式对比 以下是两种方法的具体使用场景: 1. **直接调用 `run()`** 如果直接调用了 `run()` 方法而不是通过 `start()`,则不会真正开启新的线程;相反,这相当于在一个单一线程环境中运行了 `run()` 所包含的内容。换句话说,这种方式失去了并发的优势[^3]。 2. **通过 `start()` 开启线程** 当需要真正的多线程支持时,应该始终使用 `start()` 方法。这样不仅可以利用操作系统的调度机制让多个任务同时进行,还可以享受更复杂的线程管理功能,比如同步原语等。 下面是一个简单的例子展示两者的差异: ```python import threading class MyThread(threading.Thread): def run(self): print(f"{self.name} is running") def main(): t = MyThread() # 错误示范 - 不会启动新线程 t.run() # 输出:"MyThread-1 is running" # 正确示范 - 将启动新线程 t.start() # 可能输出:"Thread-1 is running" if __name__ == "__main__": main() ``` 在这个例子中,第一次调用 `t.run()` 并没有实际启动任何新线程,而只是简单地打印了一条消息。第二次调用 `t.start()` 则确实开启了另一个独立的工作单元,并且它的行为取决于操作系统如何安排时间片给各个进程或线程。 #### 总结 为了充分利用 Python 提供的多线程能力,在大多数情况下都应该优先考虑使用 `start()` 方法而非手动调用 `run()` 。只有当你明确知道不希望引入额外开销或者根本无需涉及异步处理的时候才可能例外性地单独调用后者。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值