CSIC_716_20191206【并发编程理论基础】
进程:正在执行的一个过程,进程是对正在执行过程的一个抽象。区别于程序,
进程的三种状态: 进程是动态的。
就绪态ready: 进程具备运行状态,等待操作系统分配处理器
运行状态running:进程正在占用处理器运行。 运行态的进程当遇到IO时,就会变成阻塞态,当超过时间片时,会变成就绪态
阻塞态blocked:进程不具备运行条件,正在等待某个事件的完成
python中开启多个进程的方法:
1、定义函数方式,开启新的子进程,但是没有手动回收子进程,注意:如果主进程和子进程能正常结束,则进程都会被回收,可以通过操作系统查看PID号。主进程和子进程是异步的。
from multiprocessing import Process
import time def task(name):
print(f'start..{name}..')
time.sleep(3)
print(f'end..{name}...') if __name__ == '__main__':
# Process()实例化的时候,args代表target所指函数中的参数,如果没有参数,就不需要args
pro_obj = Process(target=task, args=('reax',)) # 定义元祖,如果只有一个元素,一定要加逗号
pro_obj.start()
print('start主进程')
2、开启新的子进程,并回收子进程,此时,主进程一定会等子进程执行完成,进程回收之后 join( )。
def task(name):
time.sleep(4)
print(f'start..{name}..')
time.sleep(3)
print(f'end..{name}...') if __name__ == '__main__':
# Process()实例化的时候,args代表target所指函数中的参数,如果没有参数,就不需要args
pro_obj = Process(target=task, args=('reax',)) # 定义元祖,如果只有一个元素,一定要加逗号
pro_obj.start()
pro_obj.join()
print('start主进程')
3、通过继承Process类实现。
from multiprocessing import Process
import time class MyProcess(Process):
def run(self):
print(f'start...{self.name}的子进程')
time.sleep(3)
print(f'end...{self.name}的子进程') if __name__ == '__main__':
list1 = [] for line in range(2):
obj = MyProcess()
obj.start()
list1.append(obj) for obj in list1:
obj.join() print('主进程...')
多道技术:是针对一个CPU而言,
时间的复用:遇到IO或者时间占用过长时,会保留当前进程的状态,切换进程。 优点:CPU使用率高;缺点:程序执行效率低
空间的复用:一个CPU可以提供给多个进程使用。
并发:针对CPU的一个核,通过不停切换进程,造成多个进程同时运行的假象,实现伪并行。----->单核+多道技术,就可以实现并发
并行:真正实现多个进程同时运行。一定要多核。
同步:必须要等主动获取。
异步:等通知或者函数回调。
阻塞:进程挂起,什么都不做。
非阻塞:进程未挂起,还可以处理其他事。
异步同步反映的是执行者执行方式,同步表示执行者主动查询,异步表示自己不主动查询而是等待消息等机制通知。
阻塞非阻塞反映的是执行者执行状态,阻塞表示执行者等待,非阻塞表示执行者不等,而是去做其他事情。
同步阻塞、同步非阻塞、异步阻塞、异步非阻塞:
拿网上老张喝茶为例子: 同步阻塞: 老张把水壶放到火上,立等水开 同步非阻塞: 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有 异步阻塞: 老张买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。老张把响水壶放到火上,立等水开 异步非阻塞: 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶 总结: 异步同步反映的是执行者执行方式,同步表示执行者主动查询,异步表示自己不主动查询而是等待消息等机制通知。 阻塞非阻塞反映的是执行者执行状态,阻塞表示执行者等待,非阻塞表示执行者不等做其他事情。
CSIC_716_20191206【并发编程理论基础】的更多相关文章
- [ 高并发]Java高并发编程系列第二篇--线程同步
高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...
- python3全栈开发-补充UDP的套接字、操作系统、并发的理论基础
一.基于UDP的套接字 udp套接字简单示例 import socket ip_port=('1.1.1.1',8181) BUFSIZE=1024 udp_server_client=socket. ...
- python之并发编程
一 背景知识 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所 ...
- day20-多并发编程基础(一)
重新写一下吧,系统奔溃了,以前写的完全没了,悲催,今日主要写进程 1. 进程的理论知识 2. python中的进程操作 开始今日份整理,加油,你是最胖的!!! 1. 进程的理论知识 1.1 操作系统的 ...
- python下的并发编程
阅读目录 一 背景知识 二 python并发编程之多进程 三 python并发编程之多线程 四 python并发编程之协程 五 python并发编程之IO模型 六 补充:paramiko模块 七 作业 ...
- Cpython解释器下实现并发编程
一 背景知识 二 python并发编程之多进程 三 python并发编程之多线程 四 python并发编程之协程 五 python并发编程之IO模型 六 补充:paramiko模块 七 作业 一 背景 ...
- Cpython解释器下实现并发编程——多进程、多线程、协程、IO模型
一.背景知识 进程即正在执行的一个过程.进程是对正在运行的程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所有内容都 ...
- python之旅:并发编程
一 背景知识 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所 ...
- 多并发编程基础 之进程 Process
原贴 https://www.cnblogs.com/gbq-dog/p/10299663.html 1. 进程的理论知识 1.1 操作系统的背景知识 顾名思义,进程即正在执行的一个过程.进程是对正 ...
随机推荐
- EntityFramework 知识点与sql优化汇总
一.EntityFramework modelBuilder.Entity<Domain.UseOilPlanDetail>().HasRequired(x => x.MainOil ...
- 代理-jdk动态代理
1.基于接口的实现,要jdk动态代理的类必须要实现一个接口: 2.中介类:实现了InvocationHandler,并重写这个接口的 方法(public Object invoke(Object pr ...
- Linux 登录、注销与关机
Linux 登录.注销与关机 这里主要学习的是命令行环境下的相关操作. 一.登录 Linux 默认的情况下会提供六个终端来让用户登录,切换的方式为使用:[Ctrl + Alt + F1 ~ F6]的组 ...
- MyBatis 通过包含的jdbcType类型
BIT FLOAT CHAR TIMESTAMP OTHER UNDEFINED TINYINT REAL V ...
- Hadoop常用端口和定义方法
Hadoop集群的各部分一般都会使用到多个端口,有些是daemon之间进行交互之用,有些是用于RPC访问以及HTTP访问.而随着Hadoop周边组件的增多,完全记不住哪个端口对应哪个应用,特收集记录如 ...
- Delphi 打印纸张选项设置参数
{ paper selections } {$EXTERNALSYM DMPAPER_LETTER} DMPAPER_LETTER = 1; { Letter 8 12 x 11 in } {$EXT ...
- PHP ftp_chmod() 函数
定义和用法 ftp_chmod() 函数设置 FTP 服务器上指定文件的权限. 如果成功,该函数返回新的权限.如果失败,则返回 FALSE 和一个警告. 语法 ftp_chmod(ftp_connec ...
- API函数ShellExecute与ShellExecuteEx用法
ShellExecute: 1.函数功能:你可以给它任何文件的名字,它都能识别出来并打开它.2.函数原型: HINSTANCE ShellExecute( HWND hwnd, LPCTSTR lpO ...
- Likecloud-吃、吃、吃
题目背景 问世间,青春期为何物? 答曰:"甲亢,甲亢,再甲亢:挨饿,挨饿,再挨饿!" 题目描述 正处在某一特定时期之中的李大水牛由于消化系统比较发达,最近一直处在饥饿的状态中.某日 ...
- 2017年上半年,一线城市豪宅TOP50成交均价排名
辣眼睛!最新豪宅排行榜来了!释放重磅信号 东方财富网 2017-07-27 08:47 阅读:152 摘要:在中国,在买房这个问题上,不少工薪族都感到亚历山大.但是,在富豪眼里,犯难的是投资哪个房地产 ...