计算机是如何工作的下篇

news/2024/12/29 22:30:48/

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;
// 进程关联的程序信息,例如哪个程序,加载到内存中的区域等
// 分配给该资源使用的各个资源
// 进度调度信息
}

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. 进程间通信
    通过公共空间,来完成进程之间的数据交互
    使用文件,使用网络


http://www.ppmy.cn/news/1117908.html

相关文章

摄像头工程师说 Camera - 数据格式 YUV 详解(2)

Camera 数据格式 YUV 详解 概述 上一个小节我们聊到 Camera 项目项目中常用的几种图像颜色的表示方法,并重点讲述了常用的 RAW、RGB、RGBA 格式。YUV 格式伴随着视频行业的快速发展,衍生出非常复杂YUV 格式定义,比如 YUV444、YUV422、YUV42…

js知识点getComputedStyle的用法,js获取dom样式的方法

获取dom样式的方法情况分为两种&#xff1a;第一种 行内样式 第二种 其他样式 一、行内样式获取比较简单&#xff0c;一般通过element.style.attr即可获取样式。 <template><div id"demo"></div> <template> <script>var dom doc…

【Linux基础】第31讲 Linux用户和用户组权限控制命令(三)

用户组管理命令 每个用户都有一个用户组&#xff0c;系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同。如Linux下的用户属于与它同名的用户组&#xff0c;这个用户组在创建用户时同时创建。用户组的管理涉及用户组的添加、删除和修改。组…

语义分割——灰度图像转伪彩色图像

目录 检验灰度图检验代码 灰度图转伪彩色图代码转换代码使用细则 示例转换结果总结 检验灰度图 制作语义分割数据集或用训练好模型测试图像时&#xff0c;得到的结果是灰度图像&#xff0c;如下&#xff1a; 检验代码 上面图像灰度值不是全是全为0&#xff0c;灰度范围在[0…

【操作系统笔记】内存分配

内存对齐 问题&#xff1a;为什么需要内存对齐呢&#xff1f; 主要原因是为了兼容&#xff0c;为了让程序可以运行在不同的处理器中&#xff0c;有很多处理器在访问内存的时候&#xff0c;只能从特定的内存地址读取数据。换个说法就是处理器每次只能从内存取出特定个数字节的数…

Ubuntu 安装 CUDA 与 OPENCL

前言&#xff1a;最近需要做一些GPU并行计算&#xff0c;因而入坑CUDA和OPENCL&#xff0c;两者都有用到一些&#xff0c;刚好有点时间&#xff0c;同时记录一些学习过程&#xff0c;排掉一些坑&#xff0c;这篇是环境安装篇&#xff0c;基本跟着走就没什么问题&#xff0c;环境…

什么情况下使用微服务?

单体架构图参考网络&#xff1a; 1. 什么是单体应用 单体应用就是将应用程序的所有功能都打包成一个独立的单元&#xff0c;最终以一个WAR包或JAR包存在&#xff0c;没有外部的任何依赖&#xff0c;里面包含DAO、Service、UI等所有的逻辑。 优点&#xff1a; &#xff11;&…

系统架构设计师(第二版)学习笔记----需求工程

【原文链接】系统架构设计师&#xff08;第二版&#xff09;学习笔记----需求工程 文章目录 一、需求定义1.1 需求包含的内容1.2 软件需求的3个不同层次1.3 需求工程的阶段1.4 需求管理的主要内容 二、需求获取2.1 需求获取的基本步骤2.2 需求获取方法2.3 需求讨论会参与人员2.…