当前位置: 首页 > news >正文

多线程-1-基础写法

基础

线程是调度的基本单元:

现代操作系统以线程作为调度和分派的基本单元,进程作为拥有资源的基本单位。一个进程可以包含多个线程,共享进程中内存等资源。

I/O操作性能:

对于I/O密集型任务,线程在等待I/O操作完成时会让出CPU调度,使得其他thread可以被CPU调度。

多进程:

虽然多进程不受GIL限制,但是进程的创建和销毁消耗的资源比线程要大,在I/O密集型任务场景下,关键瓶颈在于I/O设备而非CPU,所以多线程带来的并发优势已经足够,使用多进程可能会因为进程的创建和销毁带来的资源消耗导致性能下降。

multithread

多线程写法1

通过threading实例化多个线程,使用start方法启动并使用join方法使得主线程等待子线程执行。

# 多线程写法 1
import threading 
from time import sleep
import timedef get_detail_html(url):print("get detail html started")sleep(2)print("get detail html end")def get_detail_url(url):print("get detail url started")sleep(2)print("get detail url end")if __name__ == "__main__":t1 = threading.Thread(target=get_detail_html, args=("www.baidu.com",))t2 = threading.Thread(target=get_detail_url, args=("www.baidu.com",))start_time = time.time()t1.start()t2.start()# 使用join方法使得主线程等待线程执行完成   否则主线程不会等待子线程,就会导致,子线程执行中的时候,主线程执行时间加减t1.join()t2.join()end_time = time.time()print(end_time - start_time)

增加需求:当主线程退出的时候,将子线程kill掉,需要将子线程设置为守护线程

t1.setDaemon(True)
t2.setDaemon(True)

增加需求:主线程等待子线程执行完成,再进程主线程后续的代码逻辑

t1.join()
t2.join()

多线程写法 2

通过继承Thread类来实现多线程。

直接继承thread类,重写run方法。

import threading
import time
class GetDetailHtml(threading.Thread):def __init__(self, group = None, target = None, name = None, args = ..., kwargs = None, *, daemon = None):super().__init__(group, target, name, args, kwargs, daemon=daemon)def run(self):print("get detail html started")time.sleep(2)print("get detail html end")class GetDetailUrl(threading.Thread):def __init__(self, group = None, target = None, name = None, args = ..., kwargs = None, *, daemon = None):super().__init__(group, target, name, args, kwargs, daemon=daemon)def run(self):print("get detail url started")time.sleep(2)print("get detail url end")if __name__ == "__main__":t1 = GetDetailHtml()t2 = GetDetailUrl()start_time = time.time()t1.start()t2.start()# 使用join方法使得主线程等待线程执行完成   否则主线程不会等待子线程,就会导致,子线程执行中的时候,主线程执行时间加减t1.join()t2.join()end_time = time.time()print(end_time - start_time)

http://www.dtcms.com/a/286969.html

相关文章:

  • 顺理成章学RL-1(based Stanford CS234 Reinforcement Learning)
  • Webstorm 前端断点调试
  • pom.xml文件中的${}变量从哪里传值
  • Couchbase 可观测性最佳实践
  • ModbusRTU转profibus网关与涡街液体流量计通讯读取流量计温度
  • Android性能优化之启动优化
  • python学智能算法(二十三)|SVM-几何距离
  • Python 入门手札:从 0 到会--第九天Python的模块化编程--模块、包以及常见系统模块和第三方模块总结
  • 微店平台商品详情接口技术实现指南
  • C语言:预处理
  • 软件测试全谱系深度解析:从单元到生产的质量保障体系
  • JavaScript笔记
  • 功能安全之BIST的基本原理
  • 关于tftp怎么把res文件夹传输给开发板的操作步骤:
  • 通过代码识别大小端模式
  • 先让 AI 学会害怕,再让它握紧方向盘
  • Unity 多人游戏框架学习系列六
  • YT Config Tool 添加FreeRTOS模块
  • 【linux V0.11】kernel(水)
  • 2025年6月GESP(C++二级): 幂和数
  • 游戏盾能否保护业务免受DDoS攻击吗?
  • Django母婴商城项目实践(五)- 数据模型的搭建
  • 【Python练习】 049. 编写一个函数,实现简单的文本编辑器功能,支持增删改查
  • 你的品牌需要一个AI首席内容官——解构BrandCraft如何解决内容创作的终极痛点
  • 枚举算法入门
  • 【2025/07/18】GitHub 今日热门项目
  • 北斗网格位置码详解:经纬度到二维网格码的转换(非极地)
  • 针对BERT模型的理解
  • 04-三思而后行:解锁AI的“内心戏”
  • VMware安装Win10教程(附安装包)虚拟机下载详细安装图文教程