Thread类的start() 方法和run()方法

Thread类是Java用来创建线程的一个类,实现多线程的途径;

线程的状态:

 在Java中线程一般有五种状态分别是:创建,就绪,运行,阻塞和死亡;

1. 创建状态:

即时完成创建线程对象的过程,但是还没有调用start()方法,此时线程就处于创建态(NEW),当前创建状态是不能被系统调度使用的;

2.就绪状态:

就是用线程对象调用start()方法后线程就会成为就绪状态(RUNNABLE),此时线程就具备了被系统调度的能力,同时线程在阻塞态或是睡眠中被唤醒也会进入就绪态;

3.运行状态:

顾名思义当前线程被系统调度,正在运行,线程会运行继承Thread类的类中重写run() 方法的中的代码;

4.阻塞状态:

线程正在运行时被暂停,通常是等待某些资源的准备(例如用户输入)。sleep,suspend,wait等方法都可以导致线程阻塞。

5.死亡状态:

如果一个线程的run方法执行结束或者调用stop方法后,该线程就会死亡。对于已经死亡的线程,无法再使用start方法令其进入就绪。

start()方法:

start()方法是用来启动线程的,它是用来把线程从创建状态转换成就绪状态的( NEW -----> RUNNABLE ) 如果一个线程被创建出来,但是不调用start()方法,它是永远会处于创建状态的,是不能被系统调度的;

值得注意的是:调用start()方法后,线程不是立马执行的,而是具备了被系统调度的能力,具体何时被执行,要看系统的调度机制如何安排。还有就是由于在线程的生命周期里,创建状态到就绪状态是单向的且只能执行一次因此同一个线程对象的start()方法也只能被调用一次;

run()方法:

其实run()方法就是普通方法,主动调用和调用普通方法一样,会顺序执行一次;

但如果是主动调用,那么该run()方法就是在主线程main上运行的,并不会在子线程上运行,要想实现多线程,在子线程上运行就需要使用start()方法,在调用start()方法后,如果系统调度了当前线程,那么会自动执行run()方法;

### 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、付费专栏及课程。

余额充值