进程和线程

2019-08-09  本文已影响0人  GOGOYAO

参考资料

进程与线程的一个简单解释

1. 举例说明线程和进程的关系

具体图例见:进程与线程的一个简单解释

2. 进程和线程的区别

2.1. 基本概念

进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。程序运行时系统就会创建一个进程,并为它分配资源,然后把该进程放入进程就绪队列,进程调度器选中它的时候就会为它分配CPU时间,程序开始真正运行。每个进程之间 pcb 独立,且 pcb 指向的资源也是独立的(此处还涉及 COW 机制)。
线程是程序执行时的最小单位,它是进程的一个执行流,是CPU调度和分派的基本单位,一个进程可以由很多个线程组成,线程间共享进程的所有资源,每个线程有自己的堆栈和局部变量。线程由CPU独立调度执行,在多CPU环境下就允许多个线程同时运行。同样多线程也可以实现并发操作,每个请求分配一个线程来处理。每个进程之间 pcb 独立,但 pcb 指向的资源是共享的。在Linux内核中创建进程和线程,入口是统一的均是do_fork(),但是pthread_create=>clone=>do_fork会传入以下clone_flags参数,标识这些资源需要共享,这就成了创建线程的概念了。

clone_flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|...

2.2. 区别对比

2.3. 多线程和多进程的适用场景

  1. 需要频繁创建销毁的优先用线程。
    实例:web服务器。来一个建立一个线程,断了就销毁线程。要是用进程,创建和销毁的代价是很难承受的。
  2. 需要进行大量计算的优先使用线程。
    所谓大量计算,当然就是要消耗很多cpu,切换频繁了,这种情况先线程是最合适的。
    实例:图像处理、算法处理
  3. 强相关的处理用线程,弱相关的处理用进程。
    什么叫强相关、弱相关?理论上很难定义,给个简单的例子就明白了。
    一般的server需要完成如下任务:消息收发和消息处理。消息收发和消息处理就是弱相关的任务,而消息处理里面可能又分为消息解码、业务处理,这两个任务相对来说相关性就要强多了。因此消息收发和消息处理可以分进程设计,消息解码和业务处理可以分线程设计。
  4. 可能扩展到多机分布的用进程,多核分布的用线程。
  5. 都满足需求的情况下,用你最熟悉、最拿手的方式。
对比
上一篇 下一篇

猜你喜欢

热点阅读