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

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

一、 进程

简单来介绍一下什么是进程,在我的理解中我是把每一个任务都当成一个进程,例如:我打开了电脑微信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.同一个进程中的线程之间,可能会互相干扰,抛出异常,会影响到其它的线程,会把整个进程中的所有线程搞崩溃,从而引发线程安全问题。

相关文章
|
3月前
|
存储 Linux API
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
|
1月前
|
并行计算 Linux
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
149 67
|
2月前
|
SQL 监控 网络协议
YashanDB进程线程体系
YashanDB进程线程体系
|
3月前
|
数据采集 Java Linux
面试大神教你:如何巧妙回答线程优先级这个经典考题?
大家好,我是小米。本文通过故事讲解Java面试中常见的线程优先级问题。小明和小华的故事帮助理解线程优先级:高优先级线程更可能被调度执行,但并非越高越好。实际开发需权衡业务需求,合理设置优先级。掌握线程优先级不仅能写出高效代码,还能在面试中脱颖而出。最后,小张因深入分析成功拿下Offer。希望这篇文章能助你在面试中游刃有余!
68 4
面试大神教你:如何巧妙回答线程优先级这个经典考题?
|
3月前
|
数据采集 Java 数据处理
Python实用技巧:轻松驾驭多线程与多进程,加速任务执行
在Python编程中,多线程和多进程是提升程序效率的关键工具。多线程适用于I/O密集型任务,如文件读写、网络请求;多进程则适合CPU密集型任务,如科学计算、图像处理。本文详细介绍这两种并发编程方式的基本用法及应用场景,并通过实例代码展示如何使用threading、multiprocessing模块及线程池、进程池来优化程序性能。结合实际案例,帮助读者掌握并发编程技巧,提高程序执行速度和资源利用率。
104 0
|
4月前
|
消息中间件 调度
如何区分进程、线程和协程?看这篇就够了!
本课程主要探讨操作系统中的进程、线程和协程的区别。进程是资源分配的基本单位,具有独立性和隔离性;线程是CPU调度的基本单位,轻量且共享资源,适合并发执行;协程更轻量,由程序自身调度,适合I/O密集型任务。通过学习这些概念,可以更好地理解和应用它们,以实现最优的性能和资源利用。
134 11
|
4月前
|
Java Linux 调度
硬核揭秘:线程与进程的底层原理,面试高分必备!
嘿,大家好!我是小米,29岁的技术爱好者。今天来聊聊线程和进程的区别。进程是操作系统中运行的程序实例,有独立内存空间;线程是进程内的最小执行单元,共享内存。创建进程开销大但更安全,线程轻量高效但易引发数据竞争。面试时可强调:进程是资源分配单位,线程是CPU调度单位。根据不同场景选择合适的并发模型,如高并发用线程池。希望这篇文章能帮你更好地理解并回答面试中的相关问题,祝你早日拿下心仪的offer!
79 6
|
9月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
6月前
|
存储 缓存 算法
面试官:单核 CPU 支持 Java 多线程吗?为什么?被问懵了!
本文介绍了多线程环境下的几个关键概念,包括时间片、超线程、上下文切换及其影响因素,以及线程调度的两种方式——抢占式调度和协同式调度。文章还讨论了减少上下文切换次数以提高多线程程序效率的方法,如无锁并发编程、使用CAS算法等,并提出了合理的线程数量配置策略,以平衡CPU利用率和线程切换开销。
面试官:单核 CPU 支持 Java 多线程吗?为什么?被问懵了!
|
6月前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?