python 之 实现多线程(第三方库:threading)

1. 多线程的定义

  • 什么是进程,线程?
    线程是进程的最小执行单元,相当于不同的执行路径

2. start 和 run 的区别

start方法一个新线程将会被创建,run方法中的代码将会在新线程上运行。

3. 简单的示例

下面是一个简单的例子,它创建了两个线程,一个线程打印从 1 到 5 的数字,另一个线程打印从 'A' 到 'E' 的字母。

python3 复制代码
import threading  
import time  
  
# 定义第一个线程的任务  
def print_numbers():  
    for i in range(1, 6):  
        time.sleep(1)  # 模拟耗时操作  
        print(i, end=' ')  
    print()  
  
# 定义第二个线程的任务  
def print_letters():  
    for letter in 'ABCDE':  
        time.sleep(1)  # 模拟耗时操作  
        print(letter, end=' ')  
    print()  
  
# 创建线程  
numbers_thread = threading.Thread(target=print_numbers)  
letters_thread = threading.Thread(target=print_letters)  
  
# 启动线程  
numbers_thread.start()  
letters_thread.start()  
  
# 等待线程结束  
numbers_thread.join()  
letters_thread.join()  
  
print("All threads have finished.")

在这个例子中,print_numbers 和 print_letters 是两个函数,它们分别定义了线程要执行的任务。我们使用 threading.Thread 来创建线程,并通过 target 参数指定线程要执行的函数。然后,我们使用 start 方法来启动线程,并使用 join 方法来等待线程结束。

4. 执行结果

一个可能的输出结果是:

python 复制代码
1 A 2 B 3 C 4 D 5 E

或者数字和字母交替出现的任何其他顺序,但是每个数字或字母之间都会有一个一秒的延迟。

最后,当两个线程都执行完毕后,程序将打印出 "All threads have finished."。这通常发生在两个线程都已经完成了它们的 join 调用之后,确保了主线程会等待这两个线程执行完毕再继续执行。

相关推荐
Mr_Xuhhh6 小时前
Java泛型进阶:从基础到高级特性完全指南
开发语言·windows·python
老天文学家了6 小时前
蓝桥杯备战Python
开发语言·python
ID_180079054737 小时前
除了 Python,还有哪些语言可以解析 JSON 数据?
开发语言·python·json
FreakStudio8 小时前
小作坊 GitHub 协作闭环:fork-sync-dev-pr-merge 实战指南
python·单片机·嵌入式·面向对象·电子diy
普通网友9 小时前
阿里云国际版服务器,真的是学生党的性价比之选吗?
后端·python·阿里云·flask·云计算
小陈工9 小时前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全
陈晓明start10 小时前
【python】豆包模型,自动生成测试用例初探索
python
阿kun要赚马内10 小时前
Python中元组和列表差异:底层结构分析
开发语言·python
万添裁10 小时前
pytorch的张量数据结构以及各种操作函数的底层原理
人工智能·pytorch·python