zoukankan      html  css  js  c++  java
  • 进程,线程与协程

    进程

    一段程序的执行过程,资源分配的基本单位,进程有三种状态,就绪、运行和阻塞.一个程序运行时,系统就会创建一个进程,并为它分配资源,然后把进程放入进程就绪队列(就绪),等到进程调度器选中它时就会为其分配CPU时间,程序开始真正执行(运行),当程序条件不够的时候,需要等待条件满足才能执行(阻塞)

    线程

    程序执行时的最小执行单元,是进程的执行流,一个进程可以有多个线程组成,线程间共享进程的所有资源,每个线程有自己的堆栈和局部变量.

    一个程序至少一个进程,一个进程至少一个线程.

    进程线程比较

    1.同一进程的线程共享本进程的地址空间,进程之间则是独立的地址空间
    2.同一进程内的线程共享本进程的资源(内存,I/O cpu),单进程之间的资源是独立的.
    3.线程执行开销小,但一个线程的死掉就等于整个进程死掉;进程比线程健壮,单进程切换时耗费资源较大,效率差
    4.线程之间的通信更方便,同一进程下的线程共享全局变量、静态变量等数据,而进程之间的通信需要以通信的方式(IPC)进行。不过如何处理好同步与互斥是编写多线程程序的难点。
    5.进程是资源分配的最小单位,线程是程序执行的最小单位.

    多线程,多进程 均可实现并发.线程快而进程可靠性高
    多进程编程,进程之间独立数据空间,数据传递需要依靠通信机制,编程调试简单,可靠性高 但是 创建,销毁,切换速度变慢,内存.资源占用大
    多线程 多线程间数据资源贡献,通讯方便快捷,创建销毁切换速度快,内存,资源占用大,但是,编程调试复杂,可靠性较差

    协程

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

    协程与线程

    1.一个线程可以多个协程,一个进程也可以单独拥有多个协程

    2.线程进程都是同步机制,而协程则是异步

    3.协程能保留上一次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态

  • 相关阅读:
    vmware centos .net core sdk开发测试
    Unable to bind to http://localhost:8080 on the IPv6 loopback interface: 'Cannot assign requested address'.
    把bootstrap4 dropdown 的导航下拉菜单触发方式改为鼠标浮动触发
    vs项目同步到gitee方法
    PetaPoco轻量级ORM框架
    本田汽车车机大屏破解教程
    SqlServer 游标逐行更新数据,根据上一行的数据来更新当前行
    Angular 2/4/5+ 重复点击菜单刷新界面
    Ionic 2 + 手动搭建开发环境教程 【转】
    在过去五分钟内,TypeScript语言服务以外终止了5次
  • 原文地址:https://www.cnblogs.com/yimingwang/p/9494501.html
Copyright © 2011-2022 走看看