进程线程与协程
进程
进程是操作系统资源分配的基本单位
默认情况下一个进程提供一个线程(主线程),线程依附在进程里,一个进程可以创建多个线程。
进程和线程的对比
进程是操作系统资源分配的基本单位,线程是cpu调度的基本单位。
线程依附于进程存在,没有进程就没有线程,进程索要资源,然后让线程执行相应的代码。
一个进程可创建多个线程。
进程之间不共享全局变量,线程之间共享,但是要注意资源竞争的问题,解决办法(互斥锁或者线程同步)。
多进程开发比单进程多线程开发稳定性要强,因为某一个进程挂了不会影响其他进程运行。
多进程开发比单进程多线程开发资源消耗大,因为每启动一个进程都需要向操作系统索要运行资源,但是线程可以共享进程中的资源,极大的提高了程序的运行效率。
进程线程协程的对比
先有进程,进程里提供线程,线程里包含多个协程。
进程是操作系统资源分配的基本单位,默认提供一个线程去执行代码。
线程是cpu调度的基本单位,cpu调度那个线程,那个线程去执行对应的代码。
进程之间不共享全局变量, 线程之间共享全局变量,但是要注意点资源竞争数据错误的问题,解决办法:互斥锁。
多进程开发比单进程多线程开发稳定性要强,但是资源开销要大。
线程之间执行是无序的,协程之间按照一定顺序交替执行的。
协程主要用在网络爬虫,网络请求,以后大家主要线程或者协程完成多任务。
开辟协程大概需要5k,开辟线程大概需要512k, 开辟进程需要资源更多。
最重要的是,协程不是被操作系统内核所管理,而完全是由程序所控制(也就是在用户态执行)。
这样带来的好处就是性能得到了很大的提升,不会像线程切换那样消耗资源。
网友评论