• 计算机是如何工作的下篇


    previewfile_29534312814

    操作系统(Operating System )

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

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

    • 对下,要管理硬件设备.

    • 对上,要给软件提供稳定的运行环境.

    因此,操作系统是软件硬件用户之间交互的媒介.

    电脑端的操作系统

    我们最熟悉的操作系统Windows的发展过程
    Windows 98 => Windows 2000 => Windows XP => Windows 7 => Windows 10 => Windows 11(最新发布)

    Linux操作系统 ~~ 程序猿必须要掌握的系统
    特别适合进行开发和部署
    该系统的应用范围:
    1.服务器
    2.嵌入式设备(如冰箱,洗衣机,空调,投影仪…)
    3.移动端设备

    Mac操作系统 ~~ 苹果电脑用的系统
    和Linux是表兄弟,
    初学编程阶段,不太适合使用mac电脑
    (注:博主人生第一台笔记本就是MacBook Air 13,用的就不适手,最后大一开学就给换了一台,ε=(´ο`*)))唉!!!)
    更推荐同价位的ROG系列的windows电脑.

    手机端的操作系统

    Android ~~ 本质上也是Linux

    IOS ~~ 和Mac同宗同源

    操作系统的定位

    在这里插入图片描述

    硬件设备:
    电脑后盖打开,看到的就都是硬件设备
    ~~1.清灰 2.扩展内存/硬盘

    驱动程序:
    JDBC的驱动程序就是让JDBC和各个数据库厂商的API进行适配
    ~~和电脑转接头(适配器)一样
    硬件设备,种类繁多,厂商各异.
    硬件厂商在开发硬件的同时会提供驱动.
    电脑装了对应驱动,才能让系统正确识别硬件设备.

    操作系统内核:
    ~~ 操作系统的核心功能
    =>管理,对上要管理硬件设备,对下要给软件提供稳定的运行环境

    系统调用:
    操作系统给应用程序提供的API
    比如有个程序想操作一下硬件设备,就需要先通过系统调用,
    把操作命令告诉给系统内核,内核调用驱动程序,进一步的操作硬件设备.

    应用程序:
    ~~ 比如Java虚拟机就属于操作系统中的一个应用程序,这里不做详细介绍

    什么是进程/任务(Process/Task)

    进程是操作系统对一个正在运行的程序的一种抽象
    换言之,可以把进程程序的一次运行过程;
    同时,在操作系统内部,进程又是操作系统进行资源分配的基本单位

    一个跑起来的程序,就是一个"进程"如果没跑起来,就不算进程!!!

    image-20230917002927281

    在博主的笔记本上躺着一个idea64.exe可执行程序.
    但是此时我没有去运行它(双击就运行) => 没运行的就不是进程!!!(没跑起来的,叫做"程序")

    此刻博主的笔记本上的进程如下:

    image-20230917005708203

    进程是一个重要的"软件资源",是由操作系统内核负责管理的

    那么操作系统内核是如何管理进程的呢?

    管理 => 描述 + 组织

    • 描述: 讲清楚都有哪些属性特征
      使用结构体(C语言的结构体 ~~ 操作系统基本上都是C/C++来写的)来描述进程属性
      用来描述进程的这个结构体起了个特殊的名字,叫做 PCB (Process Control Block 进程控制块)

    • 组织: 通过一定的数据结构把多个这样的基本单位串起来
      通过双向链表(并不是一个单纯的双向链表),把多个PCB给串到一起

    创建一个进程,本质上就是创建一个PCB 这样的结构体对象,把它插入到链表中.
    销毁一个进程,本质上就是把链表上的 PCB节点删除掉.
    任务管理器查看到进程列表,本质上就是遍历这个PCB 链表

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

    计算机内部要管理任何现实事物,都需要将其抽象成一组有关联的、互为一体的数据。在 Java 语言中,我们可以通过类/对象来描述这一特征
    PCB里面描述进程的特征如下:

    1. pid 进程的身份标识符.(唯一的数字)

    2. 内存指针指向了说自己的内存是哪些

    3. 文件描述符表硬盘上的文件等其他资源

    4. 进程调度相关的属性 ~~ 留待下面讲解

    ~~ 2,3描述了进程持有了哪些硬件资源

    // 以下代码是 Java 代码的伪码形式,重在说明,无法直接运行
    class PCB {
    // 进程的唯一标识(唯一的数字) —— pid;
    // 进程关联的程序信息,例如哪个程序,加载到内存中的区域等
    // 分配给该资源使用的各个资源
    // 进度调度信息
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    CPU 分配 —— 进程调度(Process Scheduling )

    操作系统对CPU资源的分配,采用的是时间模式 —— 不同的进程在不同的时间段去使用 CPU 资源
    博主的笔记本带有的就是一个16核CPU

    image-20230917154049557

    8核16线程
    一个CPU分成8个核心,每个核心,又能一个顶两个(超线程技术)
    这种情况就视为是16核就行了!

    并行

    微观上同一时刻,两个核心上的进程,就是同时执行的.

    并发

    微观上,同一时刻,一个核心上只能运行一个进程.但是它能够对进程快速的进行切换助
    比如CPU这个核心上,先运行一下QQ音乐,再运行一下cctalk,再运行一下画图板.
    只要切换速度足够快(2.5GHz,每秒运行25亿条指令),宏观上人感知不到.
    人看起来就感觉好像是这几个进程在同时运行.
    例子:电灯闪烁频率高了,人就感觉电灯是常亮的

    内核负责处理的,应用程序(程序猿)感知不到!!因此往往也把并行和并发,统称为并发!!!
    未来除非显式声明,否则谈到并发,就是指并行+并发

    操作系统里面有一个重要的模块调度器,就负责让有限的CPU来调度执行这么多的进程

    PCB里进程调度相关的属性

    1. 进程的状态

    2. 就绪状态: 随叫随到,进程随时准备好了去CPU上执行

    3. 运行状态: 正在CPU上执行的线程所处的状态

    4. 阻塞状态: 短时间无法到CPU上执行了 ~~
      ~~比如进程在进行密集的IO操作,读写数据.在读写数据的过程中,就无法响应CPU的执行操作了

    5. 进程的优先级
      进程也是有优先级的~~操作系统进行调度并不是一碗水端平
      先给谁排,后给谁排.给谁排多点,给谁排少点…

    6. 上下文

      操作系统在进行进程切换的时候,就需要把进程执行的"中间状态"记录下来,保存好( => 存档)
      下次这个进程再上CPU上运行的时候,就可以恢复上次的状态好继续往下执行( => 读档)
      上下文本质上就是你存档的内容.
      进程的上下文,就是CPU中的各个寄存器的值.
      寄存器 ~~ CPU内置的存储数据的模块.保存的就是程序运行过程中的中间结果.

      保存上下文,就是把这些CPU寄存器的值,记录保存到内存中
      回复上下文,就是把内存中的这些寄存器值恢复回去

    7. 记账信息

      操作系统,统计每个进程在cpu上占用的时间和执行的指令数目,
      根据这个来决定下一阶段如何调度.

    内存分配 —— 内存管理(Memory Manage)

    虚拟地址空间 ~~ 程序中所获取到的内存地址,并非是真实的物理内存的地址
    而是经过了一层抽象,虚拟出来的地址.

    C语言学过的指针变量,它存的数字就表示内存地址,
    不过这里的内存地址,就是虚拟的内存地址,并非真实的物理内存地址!!

    内存(物理上是个内存条)可以存很多数据.
    内存就可以想象成是一个大走廊,走廊非常长,
    有很多房间.每个房间大小1Byte每个房间还有个编号,从0开始依次累加.
    这个房间编号,就是"地址",这个地址也就认为是"物理地址"

    内存有个了不起的特性,随机访问(闪现)
    ~~ 访问内存上的任意地址的数据,速度都极快,时间上都差不多
    ~~ 正是这个特点,造就了数组取下标操作时间复杂度是O(1)

    针对进程使用的内存空间,进行"隔离"引入了虚拟地址空间!!!
    代码里不再直接使用真实的物理地址了!!!而是使用虚拟的地址.
    由操作系统和专门的硬件设备负责进行虚拟地址到物理地址的转换

    image-20230917175631796

    虚拟地址空间,主要就是为了避免进程之间相互产生影响

    CE

    CE 是一个类似于"黑客工具",功能大概就是改另一个进程里的内存数据,
    这个东西是属于操作系统,给程序猿留了个后门.
    直接通过C中的指针操作,无法针对另一个进程的内存进行修改的!!!
    但是操作系统给我们提供了一些特殊的系统调用
    ~~ 通过这些系统调用,就可以手动的操作另一个进程中的内存数据了.

    虽然进程隔离了.但是又引入了新问题.
    有些时候,确实进程之间,需要进行数据的交互(相互配合)
    ~~ 这就涉及到了进程间通信

    进程间通信(Inter Process Communication)

    所谓进程间通信,就是在隔离性的前提下找一个公共的区域(“公共空间”),让两个进程借助这个区域来完成数据交换 ~~ 就是在隔离性的前提下,做了个小小的妥协
    操作系统提供的进程间通信具体实现方式,有很多种.
    目前,主流操作系统提供的进程通信机制有: 管道,共享内存,文件,**网络,**信号量,信号

    Java圈子里,并不是很鼓励多进程编程
    ~~ 在Java圈子里,主要使用文件, socket,这两种方式完成进程间通信

    作业
    作业(job)这个术语比进程更抽象一层.
    你可以说 process是job的一种具体实现,
    但job也不一定全是 process.

    句柄
    句柄(handler)
    系统中包含很多的软件资源(进程就是一种软件资源)
    写代码就需要用到一些软件资源.
    软件资源是在操作系统内核里.在应用程序的代码中,不方便直接操作.

    句柄,就好比一个遥控器.(简单的整数/编号)
    通过系统调用借助这个句柄就可以操作软件资源了.

    例子:
    三国时代,董卓,曹操=>挟天子以令诸侯.
    天子就是天下的句柄,就是天下的遥控器

    指针也可以视为是一种句柄.对应的是内存资源.

    文章总结⭐️⭐️⭐️

    1. 操作系统,定位,结构,
      应用程序,系统调用,内核,驱动,硬件设备.

    2. 进程的概念[重点内容]
      跑起来的程序就是进程
      操作系统就需要管理很多进程
      => 描述(PCB) + 组织(双向链表)

      • 1).pid
      • 2).内存指针
      • 3).文件描述符表
      • 4).进程调度的属性,状态,优先级,上下文,记账信息
        • 4).=> 本质上是要解决"狼多肉少”的问题,让大量的进程可以在少数的CPU上同时运行
    3. 进程的虚拟地址空间
      解决的是进程之间相互影响的问题
      引入虚拟地址空间,地址越界,就能及时发现

    4. 进程间通信
      通过公共空间,来完成进程之间的数据交互
      使用文件,使用网络

  • 相关阅读:
    antd 表单校验问题记录&解决方案
    如何使用MySQL Shell连接数据库
    无人注意,新安装的 Ubuntu 23.04 不支持安装 32 位应用
    第十三届蓝桥杯大赛软件赛决赛(Java 大学A组)
    linux manual
    FFMPEG常用的一些命令介绍:音频录制、视频录制
    ELK监控nginx日志总结
    冒泡排序和快速排序
    有序单链表的插入删除操作
    自动化平台测试开发方案(详解自动化平台开发)
  • 原文地址:https://blog.csdn.net/m0_73740682/article/details/132949789