形象理解进程和线程

在学习多线程的时候看到进程和线程这两个概念,起初觉得比较难分辨。在查阅一定资料以后总结一下对这两个概念的理解。

基本概念:

定义:

进程:进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的最小,是操作系统结构的基础。

线程:线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。

区别:

1、进程拥有自己的独立地址空间,不同的进程有不同的数据空间。每启动一个进程,系统就会为它分配地址空间,建立数据表来维护代码段、堆栈段和数据段,这种操作非常昂贵。线程则是共享进程中的数据,创建一个线程系统并不会分配新的资源,而是与已有线程共享数据空间。

2、进程中使用进程间通信机制,同一进程的线程通过读取和写入数据到进程变量来通信。

理解:

计算机在运行过程中,存在很多例如QQ,LOL这样的进程,进程里又包含了很多的线程。这些进程在运行过程中都需要计算机给它们提供不同的资源,例如内存,cpu,gpu等。计算器在运行这些进程之前就会为进程准备好运行需要的资源,然后进程内的线程会从这些资源中选取自己需要的资源,完成自己的任务。因为系统切换上下文的时候会记录资源信息,而这些资源记录的最小单位是进程作为对象保存的(比如进程1有a,b,c三个线程,分别需要A,B,C三种资源,每次CPU上下文切换时,都是记录进程需要哪些资源,而不是更下一级的线程作为记录标记)。

比喻:

进程=火车,线程=车厢

  • 线程在进程下行进(单纯的车厢无法运行)
  • 一个进程可以包含多个线程(一辆火车可以有多个车厢)
  • 不同进程间数据很难共享(一辆火车上的乘客很难换到另外一辆火车,比如站点换乘)
  • 同一进程下不同线程间数据很易共享(A车厢换到B车厢很容易)
  • 进程要比线程消耗更多的计算机资源(采用多列火车相比多个车厢更耗资源)
  • 进程间不会相互影响,一个线程挂掉将导致整个进程挂掉(一列火车不会影响到另外一列火车,但是如果一列火车上中间的一节车厢着火了,将影响到所有车厢)
  • 进程可以拓展到多机,进程最多适合多核(不同火车可以开在多个轨道上,同一火车的车厢不能在行进的不同的轨道上)
  • 进程使用的内存地址可以上锁,即一个线程使用某些共享内存时,其他线程必须等它结束,才能使用这一块内存。(比如火车上的洗手间)-"互斥锁"
  • 进程使用的内存地址可以限定使用量(比如火车上的餐厅,最多只允许多少人进入,如果满了需要在门口等,等有人出来了才能进去)-“信号量”

此比喻引用知乎:https://www.zhihu.com/question/25532384/answer/411179772

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值