【Java之家-编程的衣柜】进程的基础知识及进程调度的过程

简介: 【Java之家-编程的衣柜】进程的基础知识及进程调度的过程

操作系统(Operating System)

操作系统是一组做计算机资源管理的软件的统称。目前常见的操作系统有:Windows系列、Unix系列、Linux系列、OSX系列、Android系列、iOS系列、鸿蒙等。

操作系统的定位

操作系统由两个基本功能:

  1. 防止硬件被时空的应用程序滥用;
  2. 向应用程序提供简单一致的机制来控制复杂而又通常大相径庭的低级硬件设备。

认识进程

  1. 进程:正在跑起来的程序~~正在运行的程序

进程是操作系统对一个正在运行的程序的一种抽象,换言之,可以把进程看做程序的一次运行过程;

同时,在操作系统内部,进程又是操作系统进行资源分配的基本单位。

  1. 程序是可执行文件,只是硬盘上的一个东西(静态的)
  2. 如果双击程序,此时操作系统,就会把可执行文件中的数据和指令,加载到内存中,并且让 cpu 去执行这里的指令,完成一系列相关的工作。运行起来的(动态的),进程~~
  3. 运行起来的进程会消耗CPU资源、内存资源、硬盘、网络带宽……
  4. 进程是系统分配硬件资源的基本单位
  5. 计算机中“进程”管理的核心思路:先描述再组织
  1. 描述:会使用一个专门的结构体(PCB 进程控制块)来记录一个进程里面的各个属性
  2. 组织:会使用一系列的数据结构,把多个进程进行一个有效的组织,随时方便进行遍历,查找,汇总数据……(通常是使用双向链表这样的方式来进行组织)

进程控制块抽象(PCB Process Control Block)

PCB中大概有哪些信息?

// 以下代码是 Java 代码的伪码形式,重在说明,无法直接运行
class PCB {
    // 进程的唯一标识 —— pid;
    // 进程关联的程序信息,例如哪个程序,加载到内存中的区域等
   // 分配给该资源使用的各个资源
    // 进度调度信息(留待下面讲解)
}
  1. 进程的标识(pid):同一个系统上,统一时刻中,每个进程的 pid 一定都是不同的
  2. 内存指针:表示了该进程对应的内存资源是咋样的
    内存资源中要存啥?最主要要存储的就是从exe可执行文件中加载过来的指令(二进制的,就是程序员写的代码的逻辑,进一步的再交给CPU来执行)和数据(执行的这些指令,会依赖到一些数据),需要保存一些运行过程中的中间结果之类的数据
  3. 文件描述符表:每个进程就会有一个“文件描述符表”来记录,当前这个进程正在使用哪些文件这就和硬盘资源有关了,硬盘是硬件,应用程序一般是没法直接接触到“硬件”这一层的,实际上是操作系统抽象成“文件”这样的概念,程序操作的是文件,文件实际上是存储在硬盘上的。每个进程就会有一个“文件描述符表”来记录,当前这个进程正在使用哪些文件,操作系统打开一个文件,就会产生一个“文件描述符”(就像文件的身份标识一样,当然,只在进程内部产生),同时会使用文件描述符(类似于数组),把文件描述符给组织起来CPU. 进程是需要在CPU上来执行指令的早期的CPU都是单核心的,但算力不够就变成多核心了进程的调度:
  1. 并行:同一时刻,两个进程,同时运行在两个 cpu 逻辑核心上
  2. 并发:两个进程,在同一个舞台上,轮着上。由于CPU切换进程速度极快,微观上,这俩进程是串行执行的;宏观上,看起来这俩进程就是“同时”执行的
  3. 操作系统在调度这些进程时,两种都有可能
  4. 在应用程序这一层是感知不到的(在系统内核中感知到)。由于感知不到,通常用“并发”代指“并行”和“并发”
  1. PCB中关于进程调度相关的属性(这些属性也就描述了进程对应的 cpu 资源的使用情况)
  1. 状态
    就绪状态:一个进程已经随时做好了在CPU上执行的准备
    阻塞状态/睡眠状态:进程没有准备好被调度到CPU上
    实际上,进程在系统中状态还有很多种,其中最最关键的就是 就绪 和 阻塞 状态
  2. 优先级:系统给进程进行调度的时候,也不是完全公平的,也会根据优先级的不同,来决定时间分配的权衡就可以把系统资源调配给更重要的进程上了
  3. 上下文:这些进程是轮着上的,一次运行不完。就需要保证下次上 cpu 运行的时候,能够从上次运行到的位置,继续往后运行
    对于操作系统来说所记录的上下文,就是该进程在执行过程中,CPU的寄存器中对应的数据
    存档 读档
  4. 记账信息:相当于是一个统计信息,会统计每个进程在 cpu 上都执行了多久了,执行了多少指令了,是对于进程的调度工作进行一个“兜底“

每个进程有需要有一定的内存资源

虚拟地址空间的加持下 =>进程就具有了"独立性”=>每进程有自己的虚拟地址空间 =>一个进程无法直接访问或者修改其他进程虚拟地址空间的内容=>强化了系统稳定性

通过虚拟地址空间,把进程隔离开了,但是有时候,还需要让进程之间,产生点配合/联系

进程间通信:就是在进程隔离性的基础上,开个口子,能够有限制的进行相互影响

多进程已经很好的实现了并发编程的效果了,但是有明显的缺点:

  1. 消耗资源更多
  2. 速度更慢
相关文章
|
19天前
|
算法 调度 UED
深入理解操作系统:进程调度与优先级队列
【10月更文挑战第31天】在计算机科学的广阔天地中,操作系统扮演着枢纽的角色,它不仅管理着硬件资源,还为应用程序提供了运行的环境。本文将深入浅出地探讨操作系统的核心概念之一——进程调度,以及如何通过优先级队列来优化资源分配。我们将从基础理论出发,逐步过渡到实际应用,最终以代码示例巩固知识点,旨在为读者揭开操作系统高效管理的神秘面纱。
|
16天前
|
算法 调度 UED
深入理解操作系统:进程管理与调度策略
【10月更文挑战第34天】本文旨在探讨操作系统中至关重要的一环——进程管理及其调度策略。我们将从基础概念入手,逐步揭示进程的生命周期、状态转换以及调度算法的核心原理。文章将通过浅显易懂的语言和具体实例,引导读者理解操作系统如何高效地管理和调度进程,保证系统资源的合理分配和利用。无论你是初学者还是有一定经验的开发者,这篇文章都能为你提供新的视角和深入的理解。
38 3
|
15天前
|
Java
java小知识—进程和线程
进程 进程是程序的一次执行过程,是系统运行的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,运行到消亡的过程。简单来说,一个进程就是一个执行中的程序,它在计算机中一个指令接着一个指令地执行着,同时,每个进程还占有某些系统资源如CPU时间,内存空间,文件,文件,输入输出设备的使用权等等。换句话说,当程序在执行时,将会被操作系统载入内存中。 线程 线程,与进程相似,但线程是一个比进程更小的执行单位。一个进程在其执行的过程中产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源,所以系统在产生一个线程,或是在各个线程之间做切换工作时,负担要比
24 1
|
20天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
58 4
|
21天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
21天前
|
消息中间件 算法 调度
深入理解操作系统:进程管理与调度策略
【10月更文挑战第29天】本文将带领读者深入探讨操作系统中的核心组件之一——进程,并分析进程管理的重要性。我们将从进程的生命周期入手,逐步揭示进程状态转换、进程调度算法以及优先级调度等关键概念。通过理论讲解与代码演示相结合的方式,本文旨在为读者提供对进程调度机制的全面理解,从而帮助读者更好地掌握操作系统的精髓。
31 1
|
21天前
|
算法 调度 UED
深入理解操作系统中的进程调度
【10月更文挑战第29天】探索进程调度的奥秘,本文将带你深入了解在操作系统中如何管理和控制多个并发执行的程序。从简单的调度算法到复杂的多级反馈队列,我们将逐步揭示如何优化系统性能和提高资源利用率。准备好一起揭开进程调度的神秘面纱吧!
|
26天前
|
算法 大数据 Linux
深入理解操作系统之进程调度算法
【10月更文挑战第24天】本文旨在通过浅显易懂的语言,带领读者深入了解操作系统中的进程调度算法。我们将从进程的基本概念出发,逐步解析进程调度的目的、重要性以及常见的几种调度算法。文章将通过比喻和实例,使复杂的技术内容变得生动有趣,帮助读者建立对操作系统进程调度机制的清晰认识。最后,我们还将探讨这些调度算法在现代操作系统中的应用和发展趋势。
|
1月前
|
算法 调度
深入理解操作系统:进程调度与优先级反转问题
【9月更文挑战第36天】操作系统是计算机科学中的核心概念,它管理着计算机的硬件资源和软件进程。在多任务处理环境中,进程调度是保证系统高效运行的关键机制之一。本文将探讨进程调度的基本概念、调度算法以及它们如何影响系统性能。同时,我们还将讨论优先级反转问题,这是一个在实时系统中常见的问题,它可能导致系统响应时间不可预测。通过分析优先级反转的原因和解决方案,我们可以更好地理解操作系统的设计和优化策略。
|
1月前
|
算法 调度 UED
探索操作系统的心脏:深入理解进程调度
【10月更文挑战第7天】在数字世界的海洋中,操作系统是那艘承载着软件与硬件和谐共处的巨轮。本文将带你潜入这艘巨轮的核心区域——进程调度系统,揭示它如何精准控制任务的执行顺序,保障系统的高效运行。通过深入浅出的语言,我们将一起解码进程调度的奥秘,并借助代码示例,直观感受这一机制的魅力所在。准备好,让我们启航吧!
下一篇
无影云桌面