首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
编程语言
> 详细
线程、进程、携程理解
时间:
2019-03-04 21:10:42
阅读:
347
评论:
0
收藏:
0
[点我收藏+]
标签:
异步
处理
独立
异步操作
任务
空间
激活
管道
join
并发与并行
并发
拥有处理多个任务的能力。对于单核CPU来说,只能处理并发
并行
拥有同时处理多个任务的能力,对于多核CPU,即可以并发和并行
同步与异步
同步和异步强调的是消息通信机制
同步
如果一个人这样处理:先烧水,烧水的过程中啥也不干,就一直等着,等水开后,再把茶叶放到开水壶中。这种处理方法就是同步处理
也就是说,一个任务需要多步执行,如果上一步没有执行结束,那么下一步任务就一直等待。等到上一步任务完成后(一般会有结果),下一步的任务才继续执行
在计算机中:如果一段代码A的执行中需要调用另一端代码B,那么代码A就会一直等待,直到代码B执行结束后才继续向下执行
异步
如果这样做:用一个会报警的水壶。吧凉水放到水壶里,点着火就去干其他事情了。等水壶的报警器报警的时候,他再过去吧茶叶放到开水壶里。这就是异步操作。
此人改进过程:用了一个会报警的水壶,他把凉水放到水壶里,点着火后就去干其他事了。同事交代他的仆人等水开了就把茶叶放到开水壶里,等水壶的报警器报警的时候,他的仆人就去吧茶叶放到开水壶里。
仆人就相当于计算机异步操作中的回调函数。水壶报警相当于调用回调函数
阻塞和非阻塞
阻塞和非阻塞强调的是程序在等待调用结果(消息,返回值)时的
状态
阻塞
程序在等待的过程中,线程是挂起状态。就像刚才的例子中,这个烧水的人,在等待水开的过程中在睡觉。而同步等待的过程中,线程是激活状态
非阻塞
线程、进程、携程
进程是操作系统最小的资源分配单位。线程是操作系统最小的执行单元。
进程(我用的是 multiprocessing 模块)
进程是运行着的程序以及其占用的系统资源的总和。每个进程都有独立的内存空间。
创建一个进程(Process)
子进程阻塞进程(进程对象的join方法)
守护进程
队列(Queue、JoinableQueue)【生产/消防 模型】、锁、信号量、进程池、事件、管道
线程
协程
线程、进程、携程理解
标签:
异步
处理
独立
异步操作
任务
空间
激活
管道
join
原文地址:https://www.cnblogs.com/imxiaoqi/p/10472697.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
Spring Cloud 从入门到精通(一)Nacos 服务中心初探
2021-07-29
基础的排序算法
2021-07-29
SpringBoot|常用配置介绍
2021-07-29
关于 .NET 与 JAVA 在 JIT 编译上的一些差异
2021-07-29
C语言常用函数-toupper()将字符转换为大写英文字母函数
2021-07-29
《手把手教你》系列技巧篇(十)-java+ selenium自动化测试-元素定位大法之By class name(详细教程)
2021-07-28
4-1 YAML配置文件 注入 JavaBean中
2021-07-28
【python】 用来将对象持久化的 pickle 模块
2021-07-28
马拉车算法
2021-07-28
用Python进行冒泡排序
2021-07-28
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!