计算机是如何工作的下篇

2023-09-17 19:23:04

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

更多推荐

网络安全(黑客)自学

想自学网络安全(黑客技术)首先你得了解什么是网络安全!什么是黑客网络安全可以基于攻击和防御视角来分类,我们经常听到的“红队”、“渗透测试”等就是研究攻击技术,而“蓝队”、“安全运营”、“安全运维”则研究防御技术。无论网络、Web、移动、桌面、云等哪个领域,都有攻与防两面性,例如Web安全技术,既有Web渗透,也有Web

Javascript原型和原型链的详解

🎬岸边的风:个人主页🔥个人专栏:《VUE》《javaScript》⛺️生活的理想,就是为了理想的生活!目录原型(Prototype)构造函数和原型对象原型链原型继承1.对象字面量和Object.create():可以使用字面量对象定义属性和方法,并使用Object.create()方法创建一个新对象,并将其原型设置

python特殊函数之__call__函数的作用

作用将一个类实例也可以变成一个可调用对象。详解__call__是Python中一个魔术方法(magicmethod),它用于定义对象的函数调用行为。换句话说,当你尝试调用一个具有__call__方法的对象时,Python会自动调用该方法。下面是一个简单的例子来说明__call__的作用:classMyClass:def

100天精通Python(可视化篇)——第100天:Pyecharts绘制多种炫酷漏斗图参数说明+代码实战

文章目录专栏导读一、漏斗图介绍1.说明2.应用场景二、漏斗图类说明1.导包2.add函数三、漏斗图实战1.基础漏斗图2.标签内漏斗图3.百分比漏斗图4.向上排序漏斗图5.标准漏斗图书籍推荐专栏导读🔥🔥本文已收录于《100天精通Python从入门到就业》:本专栏专门针对零基础和需要进阶提升的同学所准备的一套完整教学,

【2023,学点儿新Java-34】基本数据类型变量 运算规则:自动类型提升、强制类型转换 | 为什么标识符的声明规则里要求不能数字开头?(通俗地讲解——让你豁然开朗!)

前情提要:【2023,学点儿新Java-33】字符型变量char|布尔类型变量boolean:true、false【2023,学点儿新Java-32】Java基础小练习:根据圆周率与半径求圆的面积|温度转换|计算矩形面积|判断奇偶数|年龄分类【2023,学点儿新Java-31】测试:整型和浮点型变量的使用|附:计算机存

【Python】PySpark 数据计算 ③ ( RDD#reduceByKey 函数概念 | RDD#reduceByKey 方法工作流程 | RDD#reduceByKey 语法 | 代码示例 )

文章目录一、RDD#reduceByKey方法1、RDD#reduceByKey方法概念2、RDD#reduceByKey方法工作流程3、RDD#reduceByKey函数语法二、代码示例-RDD#reduceByKey方法1、代码示例2、执行结果三、代码示例-使用RDD#reduceByKey统计文件内容1、需求分析

【生物信息学】奇异值分解(SVD)

目录一、奇异值分解(SVD)二、Python实现1.调包np.linalg.svd()2.自定义三、SVD实现链路预测一、奇异值分解(SVD)SVD分解核心思想是通过降低矩阵的秩来提取出最重要的信息,实现数据的降维和去噪。ChatGPT:SVD(奇异值分解)是一种常用的矩阵分解方法,它可以将一个矩阵分解为三个矩阵的乘积

Scanner类用法(学习笔记)

Scanner类用法(学习笔记,后续会补充)1.next()用法packagecom.yushifu.scanner;importjava.util.Scanner;//utiljava工具包//Scanner类(获取用户的输入)Scanners=newScanner(System.in);//通过Scanner类的n

论文阅读 - Outlier detection in social networks leveraging community structure

目录摘要1.Introduction2.Relatedworks3.Preliminaries3.1.模块化度量3.2.Classesofoutliers3.2.1.点异常3.2.2.Contextualanomalies3.2.3.Collectiveanomalies3.3.Problemdefinition3.4

PBR纹理的10种贴图

PBR是基于物理的渲染的首字母缩写。它试图通过模拟材料如何吸收和反射光,以模仿现实世界中的光流的方式产生视觉效果。最近的游戏引擎由于其逼真的效果而越来越多地使用PBR纹理。对于实时渲染,它们被认为是真实世界场景的最佳近似值。推荐:用NSDT编辑器快速搭建可编程3D场景为了创建效果,大多数渲染引擎都有其独特的工作流程。但

NExT-GPT: Any-to-Any Multimodal LLM论文笔记

论文https://arxiv.org/pdf/2309.05519.pdf代码https://github.com/NExT-GPT/NExT-GPT/tree/main1.Motivation现有的多模态大模型大都只是支持输入端的多模态(Text、Image、Video、Audio等),但是输出端都是Text。也有

热文推荐