[JavaEE]初始操作系统--进程

news/2024/9/12 3:57:51/

 


专栏简介: JavaEE从入门到进阶

题目来源: leetcode,牛客,剑指offer.

创作目标: 记录学习JavaEE学习历程

希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长.

学历代表过去,能力代表现在,学习能力代表未来! 


目录

1. javaEE概述

2. 计算机发展史

3. 冯诺依曼体系

4. 操作系统

4.1 操作系统的定位

4.2 什么是进程/任务

4.3 进程控制块抽象

4.4 进程控制块的属性

 4.4并行与并发的区别

4.5 进程调度

4.6 内存分配 --- 内存管理

4.7 进程间通信


 前言

由于JavaEE涉及许多计算机操作系统中多线程的知识 , 本文作为javaEE的第一篇文章 , 旨在了解多线程的基础知识 , 为后续JavaEE并发编程的学习打好基础.


1. javaEE概述

javaEE是基于javaSE基础构建的, 用来实现企业级和Web应用级企业的开发, 它不是编程语言而是一系列的技术规范和实现, 技术平台的核心思想是容器加组件.


2. 计算机发展史

计算机的需求在人类的历史中广泛存在, 发展大体经历了从一般计算机工具到机械计算机再到目前的电子计算机的发展历程.

人类对计算机的需求, 驱动我们不断的发明, 改善计算机.目前这个时代是"电子计算机"的时代, 发展的潮流是:更快速, 更稳定, 更微型,.


3. 冯诺依曼体系

现代计算机大多遵循冯诺依曼体系

  • 输入设备 : 用户给计算机发号施令的设备(键盘 , 鼠标 , 摄像头 , 麦克风)
  • 输出设备 : 计算机个用户汇报结果的数据(显示器 , 音响)
  • CPU 中央处理器 : 进行算数运算和逻辑判断
  • 存储器 : 分为内存和外存, 用于存储设备(二进制存储)

影响存储空间:

硬盘 > 内存 >>CPU

影响访问速度:

CPU > 内存 > 硬盘


4. 操作系统

操作系统是一组计算机资源管理的软件的统称 , 目前常见的操作系统有 : Windows系列 , Unix系列 , Linux系列 , Android系列(本质Linux) , iOS系列(与Mac同源) , 鸿蒙等等.

4.1 操作系统的定位

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

  • 防止硬键被时空的应用程序滥用
  • 向应用程序提供API来控制复杂而又通常大相径庭的低级设备.

4.2 什么是进程/任务

一个运行起来的程序 , 就可以称之为"进程" , 如果没运行起来就只能叫程序. 同时 , 在操作系统内部 , 进程又是操作系统进行资源分配的基本单位.


4.3 进程控制块抽象

进程是一个重要的软件资源 , 是由操作系统内核负责管理的.(描述+组织)

  • 描述:

使用结构体(c语言的结构体) 来描述进程属性 , 与java中的类具有相似的功能.

用来描述进程的结构体又被称为PCB(programe control block)进程控制块

  • 组织:

通过双向链表 , 把多个PCB串联到一起.(当然实际情况更加复杂 , 这里以开源的Linux操作系统为例)

创建一个进程 , 本质上就是创建一个PCB这样的结构体对象 , 把它插入到链表中.

销毁一个进程 , 本质上就是把链表上的PCB节点删除掉.

查看任务管理器的进程列表 , 本质上就是遍历这个PCB链表 , 取出相关的资料.


4.4 进程控制块的属性

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

这些pid可以说是进程的身份证号 , 目的是区分进程. 

  • 2.内存指针 

指明了这个进程执行的代码在内存的什么位置 , 以及这个进程中执行的数据都在哪里.

  • 3.文件描述符表 

文件描述符表可以视为是一个数组 , 里面每一个元素又是一个结构体.每一个结构体对应一个文件的相关信息.进程每打开一个文件就会在文件描述符表上多增加一项.

假设我们的代码中不操作文件 , 只有一个打印"HelloWorld"的语句 , 还是需要文件描述符表~~

一个进程只要启动 , 不管是否有操作文件的代码 , 都会默认打开三个文件 , 标准输入(System.in) , 标准输出(System.out) , 标准错误(System.err).此时对应的文件描述符表 , 会创建三个表项 , 标准输入 , 标准输出 , 标准错误 , 对应下标分别是0 , 1 , 2.这个文件描述符表的下标被称为是文件描述符


 4.4并行与并发的区别

一个系统中进程有上百个 , 这些进程希望能够"同时运行""分时复用" , CPU虽然是多核但数量有限.由此引出并行与并发的概念.

  • 并行:

如果系统有多个CPU , 一个CPU执行一个线程 , 另一个CPU执行另一个线程 , 两个线程之间互不抢占CPU资源 , 我们称之为并行.

~~微观和宏观都是同时执行. 

  • 并发:

当有多个线程执行在运行时 , 如果系统只要一个线程 , 则它不可能同时运行一个以上的线程 , 它只能将CPU的运行状态划分成若干个时间段 , 再将线程分配给各个时间段运行 , 当一个线程运行时其他线程出于挂起状态 , 我们称之为并发.

~~微观串行 , 宏观并行. 

eg: 在一个CPU核心上 , 先运行一下QQ音乐 , 再运行一下TX视频....只要切换速度足够快 , 我的电脑主频是3.2GHz一秒可以执行32亿条指令(细品) , 宏观上人感知不到.

由于并行和并发是内核负责处理的 , 应用程序感知不到.因此往往也把并行和并发 , 统称为并发.

除非显示声明 , 否则谈到并发 , 就是指并行+并发.


4.5 进程调度

为了给这些进程更好的分配CPU资源 , 操作系统里面有一个重要的资源调度器 , 就负责让有限的CPU来调度执行这么多的线程.

进程调度的相关属性.

  • 进程的状态

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

运行状态:正在CPU上运行的

阻塞状态(睡眠状态):短时间无法到CPU上执行了 .eg:进程正在进行密集的IO操作 , 读写数据.

  • 进程的优先级

当有很多进程需要运行时 , CPU先给谁排 , 后给谁排 ,  给谁排多点 , 给谁排少点.

eg:(本段子纯属虚构)

小美排时间优先给小A排 , 周一周二周三都和小A逛街吃大餐可以获取物质上的实惠 , 周四周五给小B排 , 因为小B长的帅赏心悦目.周六分单双周给小C排 , 防止小C不舔了.

进程也是有优先级的~~

操作系统调度并不是一碗水端平的.

  • 上下文

操作系统在进行进程切换的时候 , 就需要把进程执行的"中间状态"记录下来保存好,下次这个进程再上CPU运行时 , 就可以恢复上次的运行状态 , 继续向下执行.

进程的上下文 , 就是CPU中的各个寄存器的值 (寄存器是CPU内置的存储数据的模块 , 保存的就是程序运行过程中的中间结果)

保存上下文 , 就是将这些寄存器的值保存到内存中去.

恢复上下文 , 就是把内存中这些寄存器的值恢复回去.

eg:

因为小美要同时和3个人谈恋爱 , 因此她必须记住上次和某个人进行都什么程度了 , 是否有啥未完成的任务之类的.

上一月

小A对小美说 , 下个月我带你去三亚玩 , 让小美提起准备准备~~

小B对小美说 , 下个月我爸过生日 , 想让小美帮忙准备准备~~

下一月

小A问小美:你准备好了吗?小美说:我给你爸买了一个剃须刀

小B问小美:你准备好了吗?小美说:我已经买了一套泳衣了.

很明显这时就穿帮了 , 为了解决这个问题 , 就需要记录好 , 上次约会都有哪些进展 , 方便下次执行.

  • 记账信息

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

eg:

小美和各个男友每相处一段时间 , 就做一个总结 , 统计一下每个人身上大概花费了多少精力.始终保持好一个合适的尺度 , 不能太远 也不能太近.让每一个人都感受到温暖.

PCB中包含的属性非常多 , 上述是主要属性~~


4.6 内存分配 --- 内存管理

内存指针所指向的并非是真实的物理地址 , 而是经过了一层抽象 , 虚拟出来的地址空间.类型与C语言学过的指针 , 这里的内存地址就是虚拟内存地址.

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

内存有个了不起的特性~随机访问.访问内存上的任意地址的数据 , 速度都极快且时间也差不多.因此造就了数组下标操作是O(1).

如果进程操作内存的物理地址就会出现如下图所示 , 如果进程1的代码出现bug就可能导致访问的内存越界 , 进程1的越界访问到进程2的内存.

eg:

当你写一个程序一运行 , 不一会QQ崩溃了 , chrome也崩溃了.....那么这锅谁背~~

 内存使用虚拟地址就可以有效解决该问题 , 操作系统的MMU一但发现进程1的访问超出了访问范围  , 此时会直接向进程反馈一个错误.(具体来说就是SIGN SEGEMENT FAULT 信号 , 引起进程的崩溃) , 这样就可以保证谁出bug谁奔溃 , 其他无关线程不受影响.增强进程间的隔离性.

主要目的就是解决进程间相互影响的问题.


4.7 进程间通信

虽然进程隔离了 , 但又引入了新的问题.有时候 , 确实进程之间 , 需要数据的交互.(相互配合)

在隔离性的基础上 , 开个口子 , 进程间通信实现方式很多 , 但核心思路是一致的.需要搞一个多个进程都能访问到"公共空间" , 基于这个公共空间来进行数据交互即可.

eg:

在当前疫情时代的背景下 , 点外卖提倡无接触配送 , 外卖小哥可以将外卖放到指点的地点就可以实现.

这里的通信方式/公共空间 , 有很多具体的体现.

JavaEE主要涉及两种方式 , 基于文件 , 基于网络.



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

相关文章

Allegro如何移动器件操作指导

Allegro如何移动器件操作指导 Allegro上可以任意移动器件,具体操作如下 选择Edit-move Find选择Symbols Point根据需要选择 Sym Origin是抓取器件的原点 Body center是抓取器件的中心 User Pick可以自定义抓取的原点,在移动整个模块的并且旋转的时候常用的命令 Sym Pin#设…

@EventPublisher + @Async 异步事件流详解

本文主要介绍Spring事件流和Async异步线程池处理,以及Async默认线程池可能会导致的问题及解决方法。 事件流 Spring可以使用以观察者模式实现的事件流操作,将业务逻辑解耦,达到职责分离的效果 Spring事件流的详解 发布事件: pu…

YOLO系列算法改进方法 | 目录一览表

文章目录YOLO系列算法改进方法 | 目录一览表一、注意力机制添加方法二、网络轻量化方法三、优化损失函数四、非极大值抑制五、“TransformerCNN”结构六、特征融合方式改进七、优化锚框生成八、激活函数改进💡魔改YOLO系列算法,助力涨点,助力…

yolov1算法思想流程简单讲解概述————(究极简单的讲述和理解)

在我想学习算法的时候,我看某些大佬特别喜欢上来就讲论文,给我搞的贼难受,毕竟本人太辣鸡了,上来这么搞看不懂,经过诸多算法的这样折磨。我打算根据自己的亲身经历和学习过程中遇到的问题出一期,先讲算法整…

【Android App】人脸识别中借助摄像头和OpenCV实时检测人脸讲解及实战(附源码和演示 超详细)

需要全部代码请点赞关注收藏后评论区留言私信~~~ 一、借助摄像头实时检测人脸 与Android自带的人脸检测器相比,OpenCV具备更强劲的人脸识别功能,它可以通过摄像头实时检测人脸,实时检测的预览空间是JavaCameraView 常用方法说明如下 setCvC…

屏幕开发学习 -- 迪文串口屏

一 前言 最近学习了一款基于图形化开发的屏幕,在摸索一周后,基本熟悉了这款产品的一个开发过程,今天给大家分享一下迪文串口屏和STM32如何建立通讯,有不足之处,还请见谅😁 二 迪文屏介绍 1.选型 我用到的…

必看知识点:Redis 中的原子操作(1)-Redis 中命令的原子性

必看知识点:Redis 中的原子操作(1)-Redis 中命令的原子性 Redis 如何应对并发访问 Redis 中处理并发的方案 业务中有时候我们会用 Redis 处理一些高并发的业务场景,例如,秒杀业务,对于库存的操作。。。 先来分析下&#xff0c…

[附源码]Python计算机毕业设计Django姜太公渔具销售系统

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

【Rust日报】2022-12-01 Extism - 使所有软件都可编程扩展

Android 13 上的内存安全语言随着进入 Android 的内存不安全代码的数量减少,内存安全漏洞的数量也随之减少。从 2019 年到 2022 年,安卓系统漏洞的比例从 76% 下降到了 35% 。在 Android 13 中,大约 21% 的新本机代码是由 Rust 编写。AOSP 中…

实现自定义Spring Boot Starter

实现自定义Spring Boot Starter一、原理二、实战1 自定义 Spring Boot Starter1.1 添加maven依赖1.2 属性类AuthorProperties1.3 自动配置类AuthorAutoConfiguration1.4 业务逻辑AuthorServer1.5 spring.factories2 测试自定义的 Spring Boot Starter2.1 新建module或者新建工程…

HTML+CSS+JS网页设计期末课程大作业 DW个人博客网站制作 web前端开发技术 web课程设计 网页规划与设计

🎉精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

【数据库与事务系列】多数据源切换

分库分表 不光是管理多个数据源,是对sql的优化、改写、归并等一系列操作的解决方案。关注的是sql语句。以shardingSphere为例,虽然也支持跟sql无关的hint策略提供路由功能,但是在sql改写以及归并过程中,依旧对sql有限制。 多数据…

C语言学习笔记(十八)

C语言学习第十八天,做昨天按位运算符的习题 /* 练习2-6 编写一个函数setbits(x, p, n, y),该函数返回对x执行下列操作后的结果值:将x中从第p位开始的n个(二进制)位设置为y中最右边的n位的值,x的其余各位保…

Java分布式系统和云计算教程

Java分布式系统和云计算教程 大规模学习分布式 Java 应用程序、并行编程、分布式计算和云软件架构 课程英文名:Distributed Systems & Cloud Computing with Java 此视频教程共4.0小时,中英双语字幕,画质清晰无水印,源码附…

map/set疑难一网打尽(含经典面试)

set的作用:判断某⼀个元素是不是在⼀个组⾥⾯ map的作用:映射,相当于字典,把⼀个值映射成另⼀个值,可以创建字典 首先要了解map和set常用的操作,对于stl容器,无非就是增删查改,但对…

20221203今天的世界发生了什么

///光大银行:执行董事、行长付万军辞任 于2022年12月2日向本行董事会提交辞呈,辞去本行执行董事、董事会风险管理委员会主任委员及委员、普惠金融发展和消费者权益保护委员会主任委员及委员、战略委员会委员及行长职务 ///奈飞据称将扩大“预览俱乐部”…

最棘手的Java面试题(上)

这是收集的10个最棘手的Java面试问题列表。这些问题主要来自 Java 核心部分 ,不涉及 Java EE 相关问题。你可能知道这些棘手的 Java 问题的答案,或者觉得这些不足以挑战你的 Java 知识,但这些问题都是容易在各种 Java 面试中被问到的,而且包括…

基于纳芯微产品的尾灯方案介绍

文章目录1.前言2.方案简介2.1 概述2.2 功能介绍2.3 DEMO资料3.主要器件介绍3.1 LED Driver3.2 LDO3.3 CAN\LIN收发器4.演示视频5.推荐阅读1.前言 最近拜访一些做尾灯模组的客户了解到,目前LED Driver依然紧缺,特别是TPS929120,BD18331这些差…

Unity Debug的简单封装

对Unity Debug的简单封装 使用前提: Project Settings-Player-Other Settings-Script Define Symbols添加 EnableLog,点击Apply 测试代码: using MTools.Debuger; using UnityEngine;public class NewBehaviourScript : MonoBehaviour {p…

【每日一题Day46】LC1796字符串中第二大的数字 | 模拟

字符串中第二大的数字【LC1796】 Given an alphanumeric string s, return the second largest numerical digit that appears in s, or -1 if it does not exist. An alphanumeric string is a string consisting of lowercase English letters and digits. 快快学完今天的&am…