3段代码详解python中的单线程、多线程和多进程

news2024/12/26 20:46:09

目录

1. 单线程:

2. 多线程:

3. 多进程:

什么时候使用单线程、多线程和多进程

总结


在并发编程中,使用适当的并发模型可以提高程序执行效率和性能。Python提供了单线程、多线程和多进程三种方式来实现并发执行任务。

单线程是指程序在同一时间只能执行一个任务,多线程是指程序可以同时执行多个任务,而多进程是指程序可以创建多个进程来执行任务。在本文中,我们将详细探讨Python中这三种并发方式的特点和使用方法,以及它们适用的场景。

当涉及到并发执行任务时,Python提供了多种方式来实现,其中包括单线程、多线程和多进程。下面是几段代码来详解这三种方式的实现。

1. 单线程:

import time

def task(name):
    print(f"Start executing task {name}")
    time.sleep(2)  # 模拟任务执行时间
    print(f"Task {name} completed")

def main():
    start_time = time.time()
    task("A")
    task("B")
    end_time = time.time()

    print(f"Total execution time: {end_time - start_time} seconds")

if __name__ == '__main__':
    main()

在这个示例中,我们使用单线程依次执行两个任务(A和B)。每个任务都需要等待2秒来完成。在这种情况下,程序按照顺序执行任务,总执行时间为4秒。

2. 多线程:

import time
import threading

def task(name):
    print(f"Start executing task {name}")
    time.sleep(2)  # 模拟任务执行时间
    print(f"Task {name} completed")

def main():
    start_time = time.time()
    thread_a = threading.Thread(target=task, args=("A",))
    thread_b = threading.Thread(target=task, args=("B",))
    thread_a.start()
    thread_b.start()
    thread_a.join()
    thread_b.join()
    end_time = time.time()

    print(f"Total execution time: {end_time - start_time} seconds")

if __name__ == '__main__':
    main()

在这个示例中,我们使用多线程并发执行两个任务(A和B)。我们创建了两个线程(thread_a和thread_b),每个线程负责执行一个任务。通过调用start()方法启动线程,然后使用join()方法等待线程的完成。总执行时间将会接近2秒,因为两个任务是并发执行的。

3. 多进程:

import time
import multiprocessing

def task(name):
    print(f"Start executing task {name}")
    time.sleep(2)  # 模拟任务执行时间
    print(f"Task {name} completed")

def main():
    start_time = time.time()
    process_a = multiprocessing.Process(target=task, args=("A",))
    process_b = multiprocessing.Process(target=task, args=("B",))
    process_a.start()
    process_b.start()
    process_a.join()
    process_b.join()
    end_time = time.time()

    print(f"Total execution time: {end_time - start_time} seconds")

if __name__ == '__main__':
    main()

在这个示例中,我们使用多进程并发执行两个任务(A和B)。我们创建了两个进程(process_a和process_b),每个进程负责执行一个任务。通过调用start()方法启动进程,然后使用join()方法等待进程的完成。总执行时间将会接近2秒,因为两个任务是并发执行的。

什么时候使用单线程、多线程和多进程

在编程中,我们可以根据任务的性质和需求选择不同的并发模型:单线程、多线程或多进程。以下是对这些并发模型使用的一些建议:

单线程:
- 当任务是简单的、顺序执行的,且没有太多的资源竞争问题时,可以选择使用单线程。例如,简单的脚本或程序,不需要处理大量的并发请求或计算密集型任务。

多线程:
- 当任务需要同时进行多个IO操作(如网络请求、读写文件)时,可以使用多线程来提高程序的响应性能。在这种情况下,每个线程可以处理一个IO操作,通过并行执行多个IO操作,降低了等待时间。
- 注意,多线程需要注意线程安全问题,如避免数据竞争或共享资源的线程访问冲突。通常可以使用锁或其他同步机制来处理这些问题。

多进程:
- 当任务是计算密集型(如图像处理、数值计算)时,可以考虑使用多进程来利用多个CPU核心的并行处理能力。每个进程可以独立执行一个任务,由操作系统进行调度。
- 多进程也适用于同时处理多个独立的任务,例如在Web服务器中,在接收一个请求时,可以将其分配给一个独立的进程进行处理,这样可以避免阻塞其他请求的执行。

需要注意的是,多线程和多进程都可能引入一些额外的开销和复杂性,如上下文切换、内存消耗等。选择合适的并发模型时,需综合考虑任务特点、系统资源和性能需求等因素。

此外,还可以考虑使用异步编程模型,如基于协程的异步框架,以充分利用CPU和IO资源,并实现高效的并发处理。这种模型通常适合于高并发的IO密集型任务,如Web服务器、爬虫等。

总结

在使用并发编程时,我们需要权衡利弊,并根据特定的应用场景选择合适的并发方式。合理利用单线程、多线程和多进程,我们可以充分发挥Python在并发执行任务方面的优势,提高程序的执行效率和性能。无论是处理IO密集型还是CPU密集型任务,Python的并发编程提供了灵活而强大的工具,帮助我们构建高效的应用程序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/875012.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

护眼灯买哪种好,2023护眼台灯推荐

护眼台灯的光照一般比较均匀,相比普通台灯,一般具有防蓝光、防频闪等功能,能够提供一个健康舒适的学习、生活灯光环境,建议选购内置智能感光模式的护眼台灯,以确保灯光亮度一直处于均衡状态,让眼睛更轻松。…

从源代码编译构建Apach Spark3.2.4

从源代码编译构建Apach Spark3.2.4 编译说明编译Apache Spark下载源码构建环境准备使用本地Maven构建更改Scala版本下载Jar包构建可运行的发行版构建异常构建成功 运行测试 编译说明 对于大多数用户来说,使用官方预编译版本的Spark已经足够满足日常需求。只有在特定…

Hands on RL 之 Proximal Policy Optimization (PPO)

Hands on RL 之 Proximal Policy Optimization (PPO) 文章目录 Hands on RL 之 Proximal Policy Optimization (PPO)1. 回顾Policy Gradient和TRPO2. PPO (Clip)3. PPO(Penalty)4. PPO中Advantage Function的计算5.实现 PPO-ClipReference 1. 回顾Policy Gradient和TRPO ​ 首…

构建Actual网页客户端镜像

什么是 Actual ? Actual 是一款超快速且注重隐私的本地优先的财务应用程序,用于管理您的财务。其核心是经过充分验证且深受喜爱的信封预算方法。它是 100% 免费和开源的。 Actual 具有多设备同步、可选的端到端加密等等功能。默认情况下,它不…

ssm医院门诊挂号系统源码和论文PPT

ssm医院门诊挂号系统源码和论文PPT008 开题报告 任务书 源码 数据库sql 论文 开发环境: 开发工具:idea 数据库mysql5.7(mysql5.7最佳) 数据库链接工具:navcat,小海豚等 开发技术:java ssm tomcat8.5 1.选题的背景和意义 …

高性能MySQL实战(二):索引

大家好,我是 方圆。我们在上篇 高性能MySQL实战(一):表结构 中已经建立好了表结构,这篇我们则是针对已有的表结构和搜索条件为表创建索引。除此之外,我还会讲一些关于索引必须要了解的知识。原文收录在我的…

原来这才叫休息!——科学家揭示真正的“休息模式”

什么叫做休息?好好休息个周末?好好出去旅游一下?但事实上,往往越休息越感觉累。为什么呢?也许我们对休息存在误解,这篇文章会帮我们分析究竟该如何休息。 为什么你睡了11个小时仍然觉得疲累?为什…

【量化课程】06_化调仓策略

文章目录 6.1 如何衡量投资组合的收益率6.1.1 投资组合收益率的计算方法6.1.2 投资组合的绝对收益率和相对收益率 6.2 如何衡量投资组合的风险6.2.1 风险的定义6.2.2 投资组合的风险6.2.3 衡量投资组合的风险 6.3 最优化方法计算投资组合的最佳仓位6.3.1 等权重6.3.2 市值加权6…

Linux下常见的代理服务器软件介绍

在Linux系统中,代理服务器是我们搭建网络环境和处理网络请求的常用工具。但是,你知道Linux下常见的代理服务器软件有哪些吗?本文将为你带来对几款常见的Linux代理服务器软件的介绍,帮助你选择适合的代理服务器。 一、Squid&#…

根据数组中元素的位置号x,y和指定的计算规则z=f(x,y)创建数组,让x,y位置上的值是znp.fromfunction()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 根据数组中元素的位置号x,y 和指定的计算规则zf(x,y) 创建数组,让x,y位置上的值是z np.fromfunction() 选择题 下列说法错误的是? import numpy as np def func(i, j): return …

书单背景图片素材哪里找?这个工具赶紧用起来

好的文案是很重要的,但是如何找到好的文案却是一件很困难的事情。以下是一些可以寻找好的文案的方法分析,以及如何把书单文章转到视频的操作分享。 1.书籍和杂志:阅读关于广告、营销、文案和创意的书籍和杂志可以帮助你了解不同的文案类型和风…

《零基础实践深度学习》(第2版)学习笔记,(二)机器学习和深度学习综述

文章目录 1. 人工智能、机器学习、深度学习的关系2. 机器学习2.1 实现原理2.2 如何实施 3. 深度学习神经网络核心概念 1. 人工智能、机器学习、深度学习的关系 **人工智能(Artificial Intelligence,AI)**是研发用于模拟、延伸和扩展人的智能…

【MySQL--->数据类型】

文章目录 [TOC](文章目录) 一、数据类型分类二、整型类型三、bit(位)类型四、float类型五、decimal类型六、char和varchar类型1.char类型2.varchar3.char与varchar的区别 七、日期与时间类型八、enum和set 一、数据类型分类 二、整型类型 数值类型有数据存储上限,而且每个类型都…

Crond计划任务和用户权限提升

目录 前言 一、一次性任务 1、at实现,atd服务 2、查看atd服务的状态:systemctl status atd 二、周期性任务 1.在/etc/crontab文件中写入计划任务 2、crontab文件的含义: 3、操作设置 三、用户权限提升 3.1 su 3.2 sudo提权 总结 前言…

【灵商课堂】知识的结束就是智慧的开始

心无挂碍,心无恐惧 1、知识不会通向智慧。 我们累积了关于很多事情的大量知识,但是要按照学到的知识去明智地行动,看起来几乎是不可能的。学校、学院和大学传授有关行为、宇宙、科学和各种技术的知识,但是这些教育中心很少帮助一个…

油耳朵适合什么样的耳机听歌,到底有没有适合油耳的耳机?

骨传导耳机就是利用震动来传递声音的耳机,在运动时佩戴骨传导耳机,可以听歌也能听周围的声音,提高了运动时的安全性。目前市面上的骨传导耳机也是琳琅满目。今天就来给大家分享下目前市面上比较常见的几款骨传导耳机。希望对正在选购骨传导耳…

【Java】教你如何实现接口防刷

文章目录 前言思路分析具体实现编写 RedisUtils定义Interceptor 改进 前言 我们在浏览网站后台的时候,假如我们频繁请求,那么网站会提示 “请勿重复提交” 的字样,那么这个功能究竟有什么用呢,又是如何实现的呢? 其实…

张驰咨询:提高企业竞争力,六西格玛设计公司(DFSS)在行动

六西格玛设计公司(DFSS)是一种专业从事六西格玛设计的企业,其主要作用是为客户提供高效的六西格玛设计服务,以帮助客户实现高品质、低成本和高效率的产品开发过程。六西格玛设计公司通常拥有一支专业的团队,具有丰富的六西格玛设计经验和技术…

Mybatis 源码 ④ :TypeHandler

文章目录 一、前言二、DefaultParameterHandler1. DefaultParameterHandler#setParameters1.1 UnknownTypeHandler1.2 自定义 TypeHandler 三、DefaultResultSetHandler1. hasNestedResultMaps2. handleRowValuesForNestedResultMap2.1 resolveDiscriminatedResultMap2.2 creat…

git一次错误提交的回滚(不同分支因merge-需回滚)

场景:提交到sit的代码,结果解决冲突merge了DEV的代码,所以要回滚到合并之前的代码 (原因是我再网页上处理了冲突,他就自动merge了,如图—所以还是idea处理冲突,可控) 方式二: &…