操作系统与进程调度

news2025/1/22 16:59:28

文章目录

  • 一、计算机操作系统
    • 1.操作系统(Operating System)
    • 2.计算机系统示意图
  • 二、进程
    • 1.进程/任务(Process/Task)
    • 2.进程控制块抽象(PCB Process Control Block)
    • 3.进程调度(Process Scheduling)
    • 4.内存管理(Memory Manage)
    • 5.进程间通信(Inter Process Communication)

一、计算机操作系统

1.操作系统(Operating System)

操作系统是一组做计算机资源管理的软件的统称,我们在日常生活常接触到的操作系统有:windows、IOS、Android、鸿蒙,以及Linux系统等等,那么操作系统是什么?计算机是如何运行的?

计算机是由软件、硬件相互配合工作;事实上,操作系统可以看做是介于软硬件之间的一组软件,主要起到两点作用:

  • 提供稳定的运行环境给软件
  • 管理好各种硬件设备

2.计算机系统示意图

下图为计算机系统示意简图,其中操作系统属于系统软件,大家可以了解一下:
计算机组成简图
当然,我们学JavaWeb最关心的不是他的硬件如何,就目前来说也不应该是操作系统是如何实现的,我们最密切关心的内容是进程管理模块

二、进程

1.进程/任务(Process/Task)

简单来说,一个运行起来的程序(.exe)就是一个进程,从操作系统的调度上来看,进程在运行时,需要向操作系统申请资源,因此进程是操作系统进行资源分配的基本单位。
在这里插入图片描述
以上的每一项任务都是一个进程,我们可以看到有一百多个进程,这么多进程同时跑起来,为了保证在计算机上的有序执行,于是需要引入进程管理~

管理:

  • 先描述:明确把这个东西有啥特征,都表示出来 ,操作系统主要是通过C/C++实现的,这里的描述其实就是用结构体/类;进程这个结构体称为“PCB”(process control block)进程块。
  • 再组织:使用一个数据结构(双向链表),把很多个这样的结构体 / 对象给整理到一起
  • //创建进程:先创建出PCB,然后把PCB加载到双向链表中
  • //销毁进程:找到链表的PCB,并且从链表上删除
  • //查看任务管理器:就是遍历链表

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

一个进程的属性是非常多的,因此在PCB中存储的是一些较为关键的属性,主要属性有以下:

class PCB {
    // 进程的唯一标识 —— pid;
    // 进程关联的程序信息,例如哪个程序,加载到内存中的区域等    
    // 分配给该资源使用的各个资源
    // 进度调度信息(下面讲解)
}

说明:

  • 身份标识PID: 一个进程有一个唯一的身份标识
  • 内存指针:*指明了当前进程要使用的是哪一部分内存(进程是消耗一定的硬件资源的)。
  • 文件描述表:程序运行过程中,进程每次打开一个文件,就会增加一个文件描述符,文件描述符会以顺序表的方式存储构成文件描述表。
  • 辅助属性:该类属性主要是为了辅助进程调度,主要是描述与cpu资源相关的属性

3.进程调度(Process Scheduling)

计算机在执行程序时离不开CPU,CPU的核心数相当于干活的人数,线程数相当于干活效率
在这里插入图片描述
如上图,现在常见的CPU多为六核十二线程、八核十六线程等等,反观我们的进程数却经常以百为单位,注意,我们要的是同时干!!! 那么他们是如何执行这么多任务的呢?

  • 并行:同一时间,各干各的,互不打扰,进程之间就是并行的
  • 并发:先干一会儿A,再干一会儿B,再干一会C,再去干A~,只要切换够快,我们就认为ABC是并发的

通过并行+并发,我们就可以实现CPU‘同时’执行几百个进程,注意:并行和并发只有在微观上有区分,宏观上我们是区分不了的,因此我们将并发+并行统称为并发。

进程调度的辅助属性通常有以下几点:

  • 进程状态
  • 进程的优先级
  • 进程的记账信息
  • 进程的上下文

说明:

  • 进程状态:描述这个进程接下来的调度方式;阻塞状态:改进程暂时无法在CPU上执行;2.就绪状态:随时可以在CPU上执行
  • 优先级:进程在调度时要有先后顺序以及时间分配
  • 记账信息:统计进程在CPU上的执行时间,作为一定的参考依据进行调整
  • 上下文:通俗来讲就是游戏的存档、读档;具体来讲就是CPU在执行过程中,执行中间的值以及执行的计算机指令等内容

4.内存管理(Memory Manage)

这里讲到的内存管理主要是指虚拟地址空间,事实上,每个进程访问的内存地址都不是真实的,而是利用一个页表将虚拟地址空间映射到真实地址空间上
在这里插入图片描述
如图,进程直接访问内存,如果出现数组越界等等的代码bug,极有可能由一个不相干的进程引起另一个进程的bug,显然这种实现代价是极为糟糕的,使用代价也是非常大的,为了让各个进程之间互不干扰, 就出现了“虚拟地址空间”,每个进程都只能访问到自己的地址空间,成功的完成进程间的隔离。

虚拟地址主要指的是进程在访问地址时,会被操作系统通过一个中间站“页表”来映射到真实的内存地址,如果出现野指针、数组越界等等bug,会被页表报错,就无法修改真实内存地址上的内容,从而不会产生对别的进程的干扰

进程之间无法互相干扰,大大提高了操作系统的稳定运行!

5.进程间通信(Inter Process Communication)

现代的应用,要完成一个复杂的业务需求,往往无法通过一个进程独立完成,总是需要进程和进程进行配合地达到应用的目的,如此,进程之间就需要有进行“信息交换“的需求。进程间通信的需求就应运而生。
目前,主流操作系统提供的进程通信机制有如下:

  1. 管道
  2. 共享内存
  3. 文件
  4. 网络
  5. 信号量
  6. 信号

其中,网络是一种相对特殊的 IPC 机制,它除了支持同主机两个进程间通信,还支持同一网络内部非同一主机上的进程间进行通信。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/519857.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

知识点回顾(一)

1.final,finally ,finalize final?修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final&…

ChatGPT潜能无限:多个震撼应用场景一一揭晓

ChatGPT 具有对个人、公司和各个行业非常有用的各种应用程序。在本文中,我们继续解释ChatGPT 应用(基础应用场景,请点击这里查看)。 看完此篇文章中,你会非常惊讶于起潜能无限的应用场景及其强大的功能,那…

Nginx之rewrite实现URL重写

1.开篇 rewrite是nginx服务器提供的一个重要功能,用于实现URL的重写。例如我们访问https://aa.qq.com,打开的是https://age.qq.com/,这就是使用URL重写的特性来实现的。 ngx_http_rewrite_module为实现URL重写提供了指令支持。 官方文档地…

ChatGPT教程(终极版)

新建了一个网站 https://ai.weoknow.com/ 每天给大家更新可用的国内可用chatGPT 这是一篇姗姗来迟的ChatGPT教程。 小白对ChatGPT的介绍足以让你阅读我的文章。 如果你已经使用过ChatGPT,那么祝贺你发现了宝藏。未来的先进技术一定会帮助你有所收获。 前提是你可…

我的『1024』创作纪念日

记得,2020年07月22日我撰写了第1篇技术博客:《遗传算法实例解析》在这平凡的一天,我赋予了它不平凡的意义也许是立志成为一名专业T作者、也许是记录一段刚实践的经验但在那一刻,我已在创作这趟旅程中出发今天,是我成为…

百度蜘蛛简介

百度蜘蛛简介 工作机制百度蜘蛛的工作要素百度蜘蛛原理的应用Baiduspider对一个网站服务器造成的访问压力如何?Baiduspider多长时间之后会重新抓取我的网页? 工作机制 百度蜘蛛的构建的原理。搜索引擎构建一个调度程序,来调度百度蜘蛛的工作…

2023.5.13>>Eclipse+exe4j打包Java项目及获取exe所在文件的路径

Eclipseexe4j打包Java项目及获取exe所在文件的路径 1、打包exe文件1.1 打jar包1.2 打包exe2、在程序中获取exe所在路径3、遇到问题4、JDK version和class file version(Class编译版本号)对应关系5、参考文章 1、打包exe文件 1.1 打jar包 右单击项目选择“Export…” 1.2…

软考A计划-真题-分类精讲汇总-第三章(数据库)

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&am…

小程序开发中的插件、组件、控件到底有什么区别?

小程序插件代码由一些自定义组件和 JS 代码文件构成,插件开发者在发布插件时,这些代码被上传到后台保存起来。当小程序使用插件时,使用者需填写插件的 AppID 和版本号,就可从后台获取相应的插件代码。小程序代码编译时&#xff0c…

基于 CentOS 7 构建 LVS-DR 群集

如有错误,敬请谅解! 此文章仅为本人学习笔记,仅供参考,如有冒犯,请联系作者删除!! 前言: 对比 LVS 负载均衡群集的 NAT 模式和 DR 模式其各自的优势 DR 模式 原理:首先…

Hadoop之block切片

切片是一个逻辑概念 在不改变现在数据存储的情况下,可以控制参与计算的节点数目 通过切片大小可以达到控制计算节点数量的目的 有多少个切片就会执行多少个Map任务 hdfs上数据存储的一个单元,同一个文件中块的大小都是相同的 因为数据存储到HDFS上不可变&#xff0…

Qt--QString字符串类、QTimer定时器类

目录 1. QString 字符串类 dialog.cpp 2. 容器类 2.1 顺序容器 QList 示例代码: student.h student.cpp dialog.h dialog.cpp 运行结果: 2.2 关联容器 QMap 示例代码: dialog.h dialog.cpp 运行结果: 3. Qt类型 3.1 跨平台数据类型…

中断相关内容大全

中断基本概念:程序中断指计算机执行现行程序过程中,出现某种急需处理的异常情况或特殊请求,CPU暂时中止现行程序,而转去对这些异常情况或特殊请求进行处理,处理完毕后CPU又自动返回到现行程序的断点处,继续…

【刷题之路】LeetCode24——详解两两交换链表中的结点的细节

一、题目描述 原题链接:https://leetcode.cn/problems/swap-nodes-in-pairs/comments/ 题目描述:给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即&am…

linux下将结果保存为图片,因为服务器是命令行界面,无法弹出窗口

解决方法来自GitHub:https://github.com/open-mmlab/mmdetection/issues/1405 The code below can show and save image with result. import mmcv import cv2 from mmcv.runner import load_checkpoint from mmdet.models import build_detector from mmdet.apis i…

C语言结构体位域

目录 一、C语言位域是什么? 二、位域详解 定义格式: 1. 数据类型排序改变,位域长度不变 2. 数据类型排序不变,位域长度改变 3.根据以上代码的验证可以得出以下计算位域结构体数据的方法: 三.位域的结构体数据如何进行print…

感恩有你:毕业论文致谢部分写作指南

现在正值毕业论文写作最后收尾阶段,估计很多同学开始各处收集如何写致谢这个部分。之前写过一篇文章中引用一位导师的“抱怨”,文章题目为“211导师深夜含泪发文:在你长达5万字的毕业论文中,我最欣赏致谢部分”,所以为…

Java面试题spring

Spring 1、不同版本的 Spring Framework 有哪些主要功能? 2、什么是 Spring Framework? Spring 是一个开源应用框架,旨在降低应用程序开发的复杂度。它是轻量级、松散耦合的。 它具有分层体系结构,允许用户选择组件&#xff0c…

国考省考行测:资料分析题,年均增长量

国考省考行测:资料分析题,年均增长量 2022找工作是学历、能力和运气的超强结合体! 公务员特招重点就是专业技能,附带行测和申论,而常规国考省考最重要的还是申论和行测,所以大家认真准备吧,我讲一起屡屡申…

Docker基础篇

1、为什么Docker比VM快 2、帮助启动类命令 启动类命令 启动docker: systemctl start docker停止Docker: systemctl stop docker重启Docker: systemctl restart docker查看状态: systemctl status docker设置开机自启&#x…