改写run()方法是为了让线程执行自定义任务,因默认不做事;通过继承threading.Thread并重写run(),可定义线程逻辑,如处理数据或网络请求;需调用start()启动线程以触发run()自动执行,直接调用run()则失去多线程意义。

在 Python3 多线程编程中,通过继承 threading.Thread 类并改写其 run() 方法,可以自定义线程执行的逻辑。当你调用线程的 start() 方法时,Python 会自动调用你重写的 run() 方法,而不是默认的空实现。
为什么要改写 run() 函数?
默认的 run() 方法不做任何事。为了在线程中执行特定任务(比如处理数据、发送网络请求等),你需要覆盖这个方法,把你要执行的代码放进去。
如何改写 run() 函数?
步骤如下:
立即学习“Python免费学习笔记(深入)”;
- 定义一个类,继承 threading.Thread
- 在类中重写 run() 方法
- 在 run() 中编写你希望在线程中运行的代码
- 创建该类的实例,并调用 start() 启动线程
示例代码
下面是一个简单的例子,展示如何改写 run() 方法:
import threading import timeclass MyThread(threading.Thread): def run(self): print(f"线程 {self.name} 开始") time.sleep(2) print(f"线程 {self.name} 结束")
创建并启动线程
t1 = MyThread() t2 = MyThread()
t1.start() # 自动调用 run() t2.start()
t1.join() t2.join()
print("所有线程执行完毕")
在这个例子中,每个线程启动后都会执行 run() 方法中的代码,即打印开始信息、等待 2 秒、再打印结束信息。
传递参数给 run() 方法
如果你需要传参,可以通过构造函数传入,并在 run() 中使用:
import threading import timeclass Worker(threading.Thread): def init(self, task_name): super().init() self.task_name = task_name
def run(self): print(f"正在执行任务: {self.task_name}") time.sleep(1) print(f"任务完成: {self.task_name}")使用
t = Worker("下载文件") t.start() t.join()
这里通过 __init__ 接收参数,并在 run() 中使用,实现灵活的任务定义。
基本上就这些。只要继承 Thread 并改写 run(),就能让线程按你的逻辑运行。不复杂但容易忽略的是:一定要调用 start(),而不是直接调用 run(),否则就不是多线程了。











