从性能,开销对进程线程协程的理解

  
 <代码>本文由以下文章参考整理:
  http://www.cnblogs.com/Eva-J
  https://www.jb51.net/article/102004.htm  
  

进程,线程和协程的关系

  
 <代码>  
  

从性能,开销对进程线程协程的理解“> <img src=

  

进程,线程和协程的特点

  
 <代码>进程:拥有自己独立的堆和栈,既不共享堆,也不共享栈,进程由操作系统调度;
  线程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,标准线程由操作系统调度;
  协程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,协程由程序员在协程的代码里显示调度
  
  #例,进一步讲述”线程和协程”之间的区别:
  假设有一个单核的操作系统,系统上没有其它的程序需要运行,现有两个线程A和B, A和B在单独
  运行时都需要10秒来完成自己的任务,而且任务都是运算操作,线程A和B之间没有竞争和共享数据
  的问题。现在让A和B两个线程并行,则操作系统会不停的在A和B两个线程之间切换,达到一种
  伪并行的效果。
  
  如果操作系统切换的频率是每秒一次,切换的成本是0.1秒(主要是栈切换),则总共需
  20 + 19 * 0.1=21.9秒,如果使用协程的方式,可以先运行协程,一个结束的时候让位给协程,
  只发生一次切换,则总共需要20 + 1 * 0.1=20.1秒。如果操作系统是双核的,而且线程是标准线程,
  那么线程A和B可以达到真的并行,则总时间为10秒;而协程的方式仍然需要20.1秒的时间 
  

线程栈空间大小

  
 <代码> 1。线程栈:windows默认1 m, Linux默认8 m,根据线程实际需要动态扩展栈大小
  - - - - - -在windows中- - - - - -
  若美元线程需要的线程栈小于默认的1 m,则按照页面文件大小的倍数开辟,例需要10 k则开辟4 k * 3=12 k
  若美元大于1 m,例需要1025 k,则按照1 m的整数倍开辟栈空间2 m  之前
  <人力资源/>
  

进程,线程切换的性能消耗

  
 <代码>进程切换分两步:
  
  1 .切换页目录以使用新的地址空间
  
  2 .切换内核栈和硬件上下文
  
  对于linux来说,线程和进程的最大区别就在于地址空间,对于线程切换,第1步是不需要做的,第2是进程和线程
  切换都要做的。
  
  切换的性能消耗:
  
  1、线程上下文切换和进程上下问切换一个最主要的区别是线程的切换虚拟内存空间依然是相同的,但是进程切换
  是不同的。这两种上下文切换的处理都是通过操作系统内核来完成的。内核的这种切换过程伴随的最显著的性能
  损耗是将寄存器中的内容切换出。
  
  2,另外一个隐藏的损耗是上下文的切换会扰乱处理器的缓存机制。简单的说,一旦去切换上下文,处理器中所有
  已经缓存的内存地址一瞬间都作废了。还有一个显著的区别是当你改变虚拟内存空间的时候,处理的页表缓冲
  处理器(Translation Lookaside Buffer (TLB))或者相当的神马东西会被全部刷新,这将导致内存的
  访问在一段时间内相当的低效。但是在线程的切换中,不会出现这个问题 
  

未完,待续~ ~

从性能,开销对进程线程协程的理解