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 调用之后,确保了主线程会等待这两个线程执行完毕再继续执行。

相关推荐
Zhansiqi4 小时前
day42部分题目
python
小王不爱笑1324 小时前
IO 模型
开发语言·python
kishu_iOS&AI4 小时前
Conda 简要说明与常用指令
python·安全·conda
小陈工4 小时前
FastAPI性能优化实战:从每秒100请求到1000的踩坑记录
python·性能优化·django·flask·numpy·pandas·fastapi
知我Deja_Vu4 小时前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
njidf4 小时前
用Python制作一个文字冒险游戏
jvm·数据库·python
呆呆小孩4 小时前
Anaconda 被误删抢救手册:从绝望到重生
python·conda
liliangcsdn4 小时前
LLM复杂数值的提取计算场景示例
人工智能·python
人工智能AI酱5 小时前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager5 小时前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归