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

相关推荐
Polar__Star1 小时前
如何结合计划任务实现自动定时备份任务配置_全自动化运维管理
jvm·数据库·python
weixin_580614006 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_813599556 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
李可以量化6 小时前
QMT 量化实战:用 Python 实现线性回归通道,精准识别趋势中的支撑与压力(下)
python·qmt·量化 qmt ptrade
a9511416426 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
Dxy12393102166 小时前
Python 使用正则表达式将多个空格替换为一个空格
开发语言·python·正则表达式
qq_189807036 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
zhangchaoxies7 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
Luca_kill7 小时前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
zhangchaoxies7 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python