听说过多线程,多进程,今天我们看Python多任务编程

简介: 听说过多线程,多进程,今天我们看Python多任务编程

前言
作为多任务编程的基本概念,进程和线程的概念是无论如何回避不了的。很多公司面试时也会问倒二者的区别。如果到互联网上随便搜一下,就能找到关于进程和线程的文章,但是相信读过之后,懂得人会点头,不懂的还是不懂。所以本文采用另外一种方式来说明。

目录
前言
1,计算机任务执行
2,什么是多任务编程
3,进程 Process
进程三态
主要类跟函数使用
使用进程
4,线程 Thread
4.1.1 线程概述
1,计算机任务执行
​ CPU: 中央处理器(central processing unit,简称CPU) ,用于任务执行运算,主流架构形式有英特尔的x86跟ARM,ARM主要用于移动端。

​ 操作系统调用CPU执行任务

​ CPU轮询: cpu在多个任务之间快速的切换执行,因为切换的速度在微妙级别,所以看起来就像同时在执行多个任务。
一个CPU核心同一时刻只能执行一个任务
多核心CPU可以理解为多个单核心CPU的集合
​ 并发与并行
并发:多个任务同时分配给一个CPU核心切换执行,这种情况就是并发,但是多个任务并不真正的同时执行
并行:多个任务同时分配给不同的CPU核心同时执行,这种情况是并行,并行是多个任务真正的同时执行
2,什么是多任务编程
​ 多任务编程: 在一个程序中编写多个任务,在程序运行中让多个任务同时执行。

​ 实现方法: 多进程编程,多线程编程

​ 多任务编程好处

提高程序任务之间的配合
充分利用计算机资源,提高了程序任务执行效率

3,进程 Process
​ 程序是一个可执行文件,静态的存放在磁盘。
​ 进程是一个动态的过程描述,会占有计算机运行资源,有自己的生命周期。

进程三态
​ 就绪:进程具备执行条件,等待系统调度分配资源
​ 运行:进程占用cpu执行
​ 等待:进程阻塞等待,让出cpu资源

主要类跟函数使用
Process:创建进程对象

target:绑定执行的目标函数

args(元组):给target函数位置传参

kwargs(字典):给target函数键值传参

start():启动进程

使用进程
​ 模块:multiprocessing

​ 创建步骤:

​ 1,将需要新进程执行的事件封装成函数

​ 2,通过模块的Process类创建进程对象,关联函数

​ 3,通过进程对象设置进程信息与属性

​ 4,通过进程对象调用start启动进程

​ 5,通过进程对象调用join回收资源

导入模块 multiprocessing

import multiprocessing
from time import sleep

创建进程执行函数

def fun():

print('子进程函数开始执行...')    
sleep(2)    
print('子进程函数执行完成...')

windows系统必须把子进程相关代码放入if下,linux则不用

if __name__=='__main__':

#创建进程对象    
p = multiprocessing.Process(target=fun)    
#启动子进程,进程被诞生并执行fun函数内容    
p.start()    
#主线程执行任务模拟    
print('主进程函数开始执行...')    
sleep(3)    
print('主进程函数执行完成...')    
#等待回收    
p.join()

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
4,线程 Thread
4.1.1 线程概述
​ 什么是线程?

线程也叫做轻量级的进程,也是多任务编程的方式
同样可以利用计算机的多cpu资源
线程可以理解为进程中再开辟的分支任务
​ 线程特征

一个进程可以包含多个线程
线程也是一个运行行为,消耗计算机资源
一个进程中的所有线程共享这个进程的资源
多个线程之间运行互不影响
线程对于资源的消耗远小于进程

​ 线程属性

设置线程名称 setName()
获取线程名称 getName()
查看线程是否存在生命周期 is_alive()
设置daemon属性 setDaemeon()
查看aemon属性 isDaemon()
deamon为True时,主线程退出分支线程也退出,在start前设置,不与join同时使用
import threading
from time import sleep

线程函数

def write():

for i in range(3):        
    sleep(3)        
    print('正在写作!')
    

创建线程对象

t = threading.Thread(target=write)

启动线程

t.start()

回收线程

t.join()

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

源码/资料/实战项目,备注:C站

微信名片

五包辣条!
关注

21

14

23

专栏目录
多任务编程(多进程与多线程)
weixin_41560737的博客
296
什么是多任务编程 多任务编程即一个程序中编写多个任务,在程序运行时让多个任务一起运行,而不是一个一个的顺次执行。 实现多任务编程的方法: 1. 多进程编程(multiprocessing) 2. 多线程编程(threading) ------------------------------> 时间段 顺序执行 任务A 任务B 任务C 并行执行 任务A 任务B 任务C 并发执行 任务A 任务A
Python多进程并发与多线程并发编程实例总结
12-25
本文实例总结了Python多进程并发与多线程并发。分享给大家供大家参考,具体如下: 这里对python支持的几种并发方式进行简单的总结。 Python支持的并发分为多线程并发与多进程并发(异步IO本文不涉及)。概念上来说,多进程并发即运行多个独立的程序,优势在于并发处理的任务都由操作系统管理,不足之处在于程序与各进程之间的通信和数据共享不方便;多线程并发则由程序员管理并发处理的任务,这种并发方式可以方便地在线程间共享数据(前提是不能互斥)。Python对多线程和多进程的支持都比一般编程语言更高级,最小化了需要我们完成的工作。 一.多进程并发 Mark Summerfield指出,对于计算密集型
评论 14

待满茶杯_
2022.04.25

from time import sleep
def A(list):

res_list = []
for i in list:
    sleep(1)
    res_list.append(i*2)
return res_list

def B(list):

final = []
for i in list:
    sleep(1)
    final.append(i*2)
return final

if name == '__main__':

list = [1,2,3]
res_list = A(list)
final = B(res_list)
print(final)

五包辣条!
作者
回复
待满茶杯_
2022.04.26

if name == '__main__':

list = [1,2,3]
res_list = A(list)
final = B(res_list)
print(final)

直接创建两个线程或者进程就好了

目录
相关文章
|
8天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
10天前
|
安全 Java 开发者
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第9天】本文将深入探讨Java并发编程的核心概念,包括线程安全和性能优化。我们将详细解析Java中的同步机制,包括synchronized关键字、Lock接口以及并发集合等,并探讨它们如何影响程序的性能。此外,我们还将讨论Java内存模型,以及它如何影响并发程序的行为。最后,我们将提供一些实用的并发编程技巧和最佳实践,帮助开发者编写出既线程安全又高效的Java程序。
22 3
|
11天前
|
Java
Java 并发编程:深入理解线程池
【4月更文挑战第8天】本文将深入探讨 Java 中的线程池技术,包括其工作原理、优势以及如何使用。线程池是 Java 并发编程的重要工具,它可以有效地管理和控制线程的执行,提高系统性能。通过本文的学习,读者将对线程池有更深入的理解,并能在实际开发中灵活运用。
|
8天前
|
安全 算法 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第11天】 在Java中,高效的并发编程是提升应用性能和响应能力的关键。本文将探讨Java并发的核心概念,包括线程安全、锁机制、线程池以及并发集合等,同时提供实用的编程技巧和最佳实践,帮助开发者在保证线程安全的前提下,优化程序性能。我们将通过分析常见的并发问题,如竞态条件、死锁,以及如何利用现代Java并发工具来避免这些问题,从而构建更加健壮和高效的多线程应用程序。
|
12天前
|
Java
Java并发编程:深入理解线程池
【4月更文挑战第7天】在现代软件开发中,多线程编程已经成为一种不可或缺的技术。为了提高程序性能和资源利用率,Java提供了线程池这一强大工具。本文将深入探讨Java线程池的原理、使用方法以及如何根据实际需求定制线程池,帮助读者更好地理解和应用线程池技术。
15 0
|
2天前
|
调度 Python
Python多线程、多进程与协程面试题解析
【4月更文挑战第14天】Python并发编程涉及多线程、多进程和协程。面试中,对这些概念的理解和应用是评估候选人的重要标准。本文介绍了它们的基础知识、常见问题和应对策略。多线程在同一进程中并发执行,多进程通过进程间通信实现并发,协程则使用`asyncio`进行轻量级线程控制。面试常遇到的问题包括并发并行混淆、GIL影响多线程性能、进程间通信不当和协程异步IO理解不清。要掌握并发模型,需明确其适用场景,理解GIL、进程间通信和协程调度机制。
17 0
|
4天前
|
设计模式 运维 安全
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第15天】在Java开发中,多线程编程是提升应用程序性能和响应能力的关键手段。然而,它伴随着诸多挑战,尤其是在保证线程安全的同时如何避免性能瓶颈。本文将探讨Java并发编程的核心概念,包括同步机制、锁优化、线程池使用以及并发集合等,旨在为开发者提供实用的线程安全策略和性能优化技巧。通过实例分析和最佳实践的分享,我们的目标是帮助读者构建既高效又可靠的多线程应用。
|
9天前
|
监控 安全 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第10天】 在Java开发中,并发编程是提升应用性能和响应能力的关键手段。然而,线程安全问题和性能调优常常成为开发者面临的挑战。本文将通过分析Java并发模型的核心原理,探讨如何平衡线程安全与系统性能。我们将介绍关键的同步机制,包括synchronized关键字、显式锁(Lock)以及并发集合等,并讨论它们在不同场景下的优势与局限。同时,文章将提供实用的代码示例和性能测试方法,帮助开发者在保证线程安全的前提下,实现高效的并发处理。
|
8天前
|
程序员 开发者 Python
Python网络编程基础(Socket编程) 错误处理和异常处理的最佳实践
【4月更文挑战第11天】在网络编程中,错误处理和异常管理不仅是为了程序的健壮性,也是为了提供清晰的用户反馈以及优雅的故障恢复。在前面的章节中,我们讨论了如何使用`try-except`语句来处理网络错误。现在,我们将深入探讨错误处理和异常处理的最佳实践。
|
12天前
|
缓存 监控 Python
解密Python中的装饰器:优雅而强大的编程利器
Python中的装饰器是一种强大而又优雅的编程工具,它能够在不改变原有代码结构的情况下,为函数或类添加新的功能和行为。本文将深入解析Python装饰器的原理、用法和实际应用,帮助读者更好地理解和利用这一技术,提升代码的可维护性和可扩展性。

热门文章

最新文章