码迷,mamicode.com
首页 > 编程语言 > 详细

有关线程、进程、协程

时间:2018-01-04 16:25:08      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:用户   body   控制   调度   对比   单位   post   虚拟   进程间   

    进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位,每个进程都有自己的独立内存空间,不同进程通过进程间通信来通信。由于进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈,寄存器,虚拟内存,文件句柄等)比较大,但相对比较安全稳定。

    线程是进程的一个实体,是cpu调度和分派的接班单位,它是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的的全部资源。线程间通信主要通过共享内存,上下文切换,资源开销较少,但相比进程,不够稳定,容易丢失数据。

    协程是一种用户态的轻量级线程,协程的调度完全有用户控制。协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复嫌弃那保存的寄存器上下文和栈,直接操作栈则基本没有内核切换的开销,可以不加锁的访问全局变量,所以上下文的切换非常快。

有关线程、进程、协程

标签:用户   body   控制   调度   对比   单位   post   虚拟   进程间   

原文地址:https://www.cnblogs.com/hexinghao/p/8193553.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!