首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

线程 、进程、协程 三者区别

1. 进程: 通俗理解一个运行起来的程序或者软件叫做进程 1.1 每次启动一个进程都需要向操作系统索要运行资源,让进程中的线程去执行对应的代码,进程是操作系统分配资源的基本单位 1.2 默认情况下一个进程只有一个线程,线程是依附在进程里面的, 没有进程就没有线程, 当在进程里面还可以创建多个线程 1.3 如何理解进程: 把进程想成现实生活中的公司,公司可以给员工提供办公资源(办公桌椅,办公电脑等资源), 真正干活的是员工,所以员工可以想成线程,公司就是进程 2. 进程和线程的对比 2.1 进程是操作系统资源分配的基本单位,每启动一个进程都需要向操作系统索要运行资源,默认一个进程只有一个线程,线程是依附在进程里面的 2.2 线程是cpu调度的基本单位, 通过线程去执行进程中代码, 线程是执行代码的分支 2.3 多进程开发比单进程多线程开发稳定性要强,但是多进程开发比多线程开发资源开销要大 2.4 多进程开发某个进程死了不会影响其它进程的运行,但是多线程开发该进程死了那么这些线程都要进行销毁 并发: 任务数大于cpu的核数,多个任务轮流执行,由于cpu切换速度特别快,看起来像是一起运行,其实是假象。 并行: 任务数小于或者等于cpu的核数,那么多个任务是真正意义一起执行。 3. 进程、线程、协程 1.1 先有进程,然后进程可以创建线程,线程是依附在进程里面的, 线程里面可以包含多个协程 1.2 进程之间不共享全局变量,线程之间共享全局变量,但是要注意资源竞争的问题 1.3 多进程开发比单进程多线程开发稳定性要强,但是多进程开发比多线程开发资源开销要大 1.4 多线程开发线程之间执行是无序的,协程之间执行按照一定顺序交替执行 1.5 协程以后主要用在网络爬虫和网络请求,开辟一个协程大概需要5k空间,开辟一个线程需要512k空间, 开辟一个进程占用资源最多

02

[C++并发编程] 1. 并发编程入门

那么我们为什么需要并发编程呢?举个简单的例子,如果你想开发一个界面应用程序,这个程序需要若干个存有100万个数据的CSV文件进行处理,然后将处理完的数据写入到另外的文件,那么这个程序的任务就可以分为三个小部分:导入CSV文件,处理数据,写出数据,界面显示进度(导入/写出),如果不使用并发,那么需要先等所有的CSV文件导入后,然后处理数据,再处理数据的同时更新数据处理的进度,然后处理下一个数据之前需要等待当前数据写入到文件,这样的话,在处理一个任务的时候,另外的任务会处于“僵死”的状态。比如处理数据的时候,界面上的按钮将无法使用,点击界面上控件的时候,数据将无法被处理。

02
领券