【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)

目录

  • 一、 进程
      • 1.1 PID(进程标识符)
      • 1.2 内存指针
      • 1.3 文件描述符表
      • 1.4 状态
      • 1.5 优先级
      • 1.6 记账信息
      • 1.7 上下文
  • 二、线程
  • 三、总结:进程和线程之间的区别(非常非常非常重要,面试必考题)

一、 进程

简单来介绍一下什么是进程,在我的理解中我是把每一个任务都当成一个进程,例如:我打开了电脑微信APP就是一个任务,也是一个进程。
在这里插入图片描述
这里的每一个任务都是进程,然后通过C++中的结构体,这里叫做PCB(进程控制块)来描述一个进程,然后通过链表将这些PCB给连接起来,当我们查看是就是遍历该链表,将存储的信息展示出来,当打开或是删除一个进程时,只需要在链表的头或尾进行插入和删除即可,每个进程都有一个结构体PCB,然后通过数据结构组织起来就形成上面的结果。

相比大家已经对PCB(进程控制块)有了一点了解,简单来说就是来描述一个进程的结构体,当然了,在结构体中是不是还有相当多的属性来组成这个结构体的,例如:上图中的状态、CPU…等都是PCB中的一个属性,也是我们接下来要学习的重点,这里我们学习PCB中的7大属性。

分别是:

  1. PID(进程标识符)
  2. 内存指针
  3. 文件描述符
  4. 状态
  5. 优先级
  6. 记账信息
  7. 上下文

所以说一个任务是一个进程,进程也就是系统分配资源的基本单位。
接下来让我们进入真正学习进程的内容了。

1.1 PID(进程标识符)

这个PID贼好理解,就记住PID的一个身份证或是一个数字,专门用来标记这个进程的,当然了,身份证是不重复的,这里的PID也不会有重复的同时出现,当你要使用该进程时,操作系统就会根据你的这个PID来迅速拿到这个进程。
在这里插入图片描述
上图可以看到,每一个进程都有一个PID,且是唯一的。

1.2 内存指针

按我的理解来说就是在创建该进程时,需要消耗一定的系统资源的,其中内存就是一种非常重要的资源,在整个电脑中,内存就那么大一点能让你随意使用吗?那肯定当然不是啦。

先从系统这里进行申请,系统分配给你一块,你才是可以使用,由内存指针指定了一块内存资源的区域,表示了你这个进程呀就在这块区域进行活动,且不能超出该区域,每个进程都必须使用自己申请到时候内存(一亩三分地)。

由于内存指针是进程创建时就已经开辟好了的,这里我们无法进行图片展示

总结来说:内存指针就是描述一个进程都能使用哪些内存资源的。

1.3 文件描述符表

内核为每个进程维护一个文件描述符表,该表记录了文件描述符的相关信息,包括文件描述符、指向打开文件表中记录的指针。
在这里插入图片描述

简单来说就是文件描述符表描述了一个进程对于内存资源使用的情况。
上图中的CPU、内存、以及磁盘都是文件描述符表对于该进程对内存资源使用的多少进行了统计。

1.4 状态

状态又分为阻塞状态和运行状态,在系统调度中心,若是要让 这个进程到CPU上进行执行就会将它的状态转变为就绪状态在执行中转变为运行状态,但是当不想让该进程进行执行时只需要将它转变为阻塞状态即可。
在这里插入图片描述

可以清楚的看到,这些状态一共有两种,一种是正在运行状态,一种是已挂起状态,已挂起状态也可以叫做阻塞状态。

1.5 优先级

优先级也很简单,我想问一下大家,当年同时运行王者荣耀打团时和微信聊天的时候,你要是CPU会先调度谁先来进行运行,很显然的我会先运行王者荣耀,但是计算机并不知道要先运行哪一个该怎么办?

这个时候就需要我们的优先级站出来了,优先级高的进程会优先进入CPU进行执行。

1.6 记账信息

简单来说就是针对每一个进程占据了多少CPU时间,进行了一个统计,然后会根据这个统计结果来进一步的调整调度的策略,确保在下一轮调整后的调度中,确保每一个进程都能进入CPU进行调度.

总结来说就是通过记账信息来进行动态的优化,让每一个进程都能进入CPU进行执行。

1.7 上下文

我们都知道在进程的调度中可能一个进程还没有执行完就被系统调度走了,难道下一次被调度回来时要重新执行前面执行了一半的吗?很显然不是这样的。

其实上下文有点向我们玩小游戏中的读档和存档,当打到第9关卡时不想玩了,就保存文档到上下文,当我们下一次想玩的时候在通过读取存档就可以继续上一次的关卡来进行了。

当进行进入CPU执行后被调度走时,会将当前处理的数据放在上下文中,当下一次重新被调度回来时在通过读取上下文信息进行继续执行。

二、线程

通过上面的学习我们知道了什么是进程,运行一个任务就是一个进程,那么什么是线程呢?可以理解为一个进程可以由一个或多个线程组成,系统在调度时会将一个进程分成多个线程来执行,当所有线程执行完,也就代表着该进程执行完了。

并且由于进程中进行频繁的创建和销毁时,会产生很大的开销(主要体现在资源的申请和释放上面),为什么进程会比线程开销大呢,举个例子:我打开王者荣耀就是一个进程,在刚进入加载界面时是不是会很慢,因为它要加载的数据很多很多,但是当我们进入后打开英雄界面或是匹配界面为什么会快秒出来呢,打开英雄界面就相当于是一个线程,匹配界面也是一个线程,当我关闭该界面(销毁线程时)处理很快,但是我要是关闭一个界面就需要重启一下游戏(进程)时,就知道多痛苦了,也可以看出来,一个进程可以由多个线程组合来完成工作,线程也可以称之为"轻量级进程"

因此说:线程是系统进行调度的基本单位
下图描述了进程和线程的关系。、
在这里插入图片描述
每一个进程在内存空间开辟一块属于自己的内存,他们之间相互独立,也叫做内存管理
在这里插入图片描述

第二个图片可以看出来,多个线程指向了同一块内存空间,而进程也是由一块空间组成,所以说进程由一个或多个线程构成,只是构成该进程的每一个线程的内存指针相同指向同一块区域,同时线程的文件描述符表也相同都是进程对内存资源的使用情况,当然了进程中其它的属性线程也都有,除了内存指针不同和文件描述符表不同之外,其它是属性和进程一样各不相同。

三、总结:进程和线程之间的区别(非常非常非常重要,面试必考题)

1.进程时系统进行资源分配时的基本单位,线程是系统调度执行时的基本单位

2.进程是包含线程的,一个进程可以由一个或多个线程组成

3.进程由一个或多个PCB组成,一个PCB包含的属性有PID、内存指针、文件描述符表、状态、优先级、记账信息以及上下文等诸多属性。

4…每个进程都有属于自己的资源,但同一个进程中的线程会共用这一份资源(该进程中线程的内存空间和文件描述符表相同)。

5.同一个进程中的线程也是一个独立的执行流,可以执行代码,并且可以单独的参与到CPU的调度中(该进程中 ,线程的PID,状态,优先级,记账信息,上下文相同的)。

6.进程和进程之间不会相互影响,因为他们的内存空间相互独立,也叫做:内存管理

7.进程间也可以相互交换信息,但需要CPU开辟一块公共空间用于交换,该过程叫做:进程间通信

8.同一个进程中的线程之间,可能会互相干扰,抛出异常,会影响到其它的线程,会把整个进程中的所有线程搞崩溃,从而引发线程安全问题。

9.同一个进程中的线程并不是越多越好,要能够合适,达到最大效率,如果线程太多了,调度开销也可能非常明显。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/24067.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

写入文件内容

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在实例01中,虽然创建并打开一个文件,但是该文件中并没有任何内容,它的大小是0KB。Python的文件对象提供了write()…

【电路笔记】-分贝

分贝 分贝是以 10 为底的对数比,用于表示电路中功率、电压或电流的增加或减少。 1、概述 一般来说,分贝是响度的度量。 在设计或使用放大器和滤波器电路时,计算中使用的一些数字可能非常大或非常小。 例如,如果我们将两个放大器级级联在一起,功率或电压增益分别为 20 和…

os和os.path模块

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 目录也称文件夹,用于分层保存文件。通过目录可以分门别类地存放文件。我们也可以通过目录快速找到想要的文件。在Python中,并…

033.搜索旋转排序数组

题意 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给方法之前&#xff0c;nums 在预先未知的某个下标 k(0 < k < nums.length)上进行了旋转&#xff0c;使数组变为 [nums[k], nums[k1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]]&…

古字画3d立体在线数字展览馆更高效便捷

在数字时代的浪潮中&#xff0c;大连图书馆以崭新的面貌跃然屏幕之上——3D全景图书馆。这座承载着城市文化精髓与丰富知识资源的数字图书馆&#xff0c;利用前沿的三维建模技术&#xff0c;为我们呈现了一个全新的知识世界。 随时随地&#xff0c;无论您身处何地&#xff0c;只…

信息学奥赛初赛天天练-22-C++基础关键字、进制转换、结构体与联合体的实用技巧大揭秘

PDF文档公众号回复关键字:20240607 单项选择题&#xff08;共15题&#xff0c;每题2分&#xff0c;共计30分&#xff1a;每题有且仅有一个正确选项&#xff09; 1 在C中&#xff0c;下面哪个关键字用于声明一个变量&#xff0c;其值不能被修改&#xff1f;&#xff08; &#…

【Java】解决Java报错:StackOverflowError

文章目录 引言1. 错误详解2. 常见的出错场景2.1 无限递归2.2 递归深度过大2.3 方法调用层次过深 3. 解决方案3.1 优化递归算法3.2 尾递归优化3.3 增加调用栈大小3.4 检查递归终止条件 4. 预防措施4.1 使用迭代替代递归4.2 尾递归优化4.3 合理设计递归算法4.4 调整JVM参数4.5 定…

b端系统类管理平台设计前端开发案例

b端系统类管理平台设计前端开发案例

二叉树-堆的详解

一&#xff0c;树的概念 1&#xff0c;树的概念 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。 把它叫做树是因为它看起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的。 有…

vue3 + echarts 二次开发百分比饼图

效果图&#xff1a; 安装 pnpm i echarts 公共模块组件 <divclass"pie"ref"percent"style"width: 100%; height: calc(100% - 48px)"></div> import { ref, onMounted } from vue import * as echarts from echarts const prop…

【乐吾乐3D可视化组态编辑器】状态告警示例

状态告警的设置方法为两种&#xff1a; 1.通过数据点号设置&#xff08;推荐&#xff09;&#xff1a; 适用于绑定单一数据点号&#xff0c;设置逻辑简洁&#xff0c;实现简单逻辑交互 2.通过交互事件监听数据点号设置&#xff1a; 适用于绑定多个数据点号&#xff0c;实现复…

LLM大模型AI应用的三阶技术

第一阶 指令工程&#xff08;Prompt Enginner&#xff09; 设计提示&#xff08;Prompt Design&#xff09; 结果优化&#xff08;Response Optimization&#xff09; 交互设计&#xff08;Interaction Design&#xff09; 模型理解&#xff08;Model Understanding&#…

哈希经典题目(C++)

文章目录 前言一、两数之和1.题目解析2.算法原理3.代码编写 二、判定是否互为字符重排1.题目解析2.算法原理3.代码编写 三、 字⺟异位词分组1.题目解析2.算法原理3.代码编写 总结 前言 哈希表是一个存储数据的容器&#xff0c;我们如果想要快速查找某个元素&#xff0c;就可以…

MMUNet:形态学特征增强网络在结肠癌病理图像分割中的应用

MMUNet: Morphological feature enhancement network for colon cancer segmentation in pathological images. 发表在&#xff1a;Biomedical Signal Processing and Control2024--影响因子&#xff1a;3.137 南华大学的论文 论文地址&#xff1a;main.pdf (sciencedirecta…

Wakeup Source框架设计与实现

Wakeup Source 为系统组件提供了投票机制&#xff0c;以便低功耗子系统判断当前是否可以进入休眠。 Wakeup Source(后简称&#xff1a;WS) 模块可与内核中的其他模块或者上层服务交互&#xff0c;并最终体现在对睡眠锁的控制上。 1. 模块功能说明 WS的处理逻辑基本上是围绕 com…

后端进阶-分库分表

文章目录 为什么需要分库为什么需要分表 什么时候需要分库分表只需要分库只需要分表 分库分表解决方案垂直分库水平分库垂直分表水平分表 分库分表常用算法范围算法hash分片查表分片 分库分表模式客户端模式代理模式 今天跟着训练营学习了分库分表&#xff0c;整理了学习笔记。…

echarts的使用

一 echarts的使用 引入 echarts.js 文件 <script src"https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> 准备一个呈现图表的盒子 <div class"container"><div class"t_header"><span>端午…

智能视频监控平台LntonCVS视频融合共享平台保障露营安全解决方案

在当今社会&#xff0c;都市生活的快节奏和压力使得越来越多的人渴望逃离城市的喧嚣&#xff0c;寻求一种短暂的慢生活体验。他们向往在壮丽的山河之间或宁静的乡村中露营&#xff0c;享受大自然的宁静与美好。随着露营活动的普及&#xff0c;露营地的场景也变得更加丰富多样&a…

使用python绘制核密度估计图

使用python绘制核密度估计图 核密度估计图介绍效果代码 核密度估计图介绍 核密度估计&#xff08;Kernel Density Estimation&#xff0c;KDE&#xff09;是一种用于估计数据概率密度函数的非参数方法。与直方图不同&#xff0c;KDE 可以生成平滑的密度曲线&#xff0c;更好地…

LeetCode62不同路径

题目描述 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。问总共有多少条不同的路径&#xff1f; …