【Java之家-编程的衣柜】进程的基础知识及进程调度的过程

简介: 【Java之家-编程的衣柜】进程的基础知识及进程调度的过程

操作系统(Operating System)

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

操作系统的定位

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

  1. 防止硬件被时空的应用程序滥用;
  2. 向应用程序提供简单一致的机制来控制复杂而又通常大相径庭的低级硬件设备。

认识进程

  1. 进程:正在跑起来的程序~~正在运行的程序

进程是操作系统对一个正在运行的程序的一种抽象,换言之,可以把进程看做程序的一次运行过程;

同时,在操作系统内部,进程又是操作系统进行资源分配的基本单位。

  1. 程序是可执行文件,只是硬盘上的一个东西(静态的)
  2. 如果双击程序,此时操作系统,就会把可执行文件中的数据和指令,加载到内存中,并且让 cpu 去执行这里的指令,完成一系列相关的工作。运行起来的(动态的),进程~~
  3. 运行起来的进程会消耗CPU资源、内存资源、硬盘、网络带宽……
  4. 进程是系统分配硬件资源的基本单位
  5. 计算机中“进程”管理的核心思路:先描述再组织
  1. 描述:会使用一个专门的结构体(PCB 进程控制块)来记录一个进程里面的各个属性
  2. 组织:会使用一系列的数据结构,把多个进程进行一个有效的组织,随时方便进行遍历,查找,汇总数据……(通常是使用双向链表这样的方式来进行组织)

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

PCB中大概有哪些信息?

// 以下代码是 Java 代码的伪码形式,重在说明,无法直接运行
class PCB {
    // 进程的唯一标识 —— pid;
    // 进程关联的程序信息,例如哪个程序,加载到内存中的区域等
   // 分配给该资源使用的各个资源
    // 进度调度信息(留待下面讲解)
}
  1. 进程的标识(pid):同一个系统上,统一时刻中,每个进程的 pid 一定都是不同的
  2. 内存指针:表示了该进程对应的内存资源是咋样的
    内存资源中要存啥?最主要要存储的就是从exe可执行文件中加载过来的指令(二进制的,就是程序员写的代码的逻辑,进一步的再交给CPU来执行)和数据(执行的这些指令,会依赖到一些数据),需要保存一些运行过程中的中间结果之类的数据
  3. 文件描述符表:每个进程就会有一个“文件描述符表”来记录,当前这个进程正在使用哪些文件这就和硬盘资源有关了,硬盘是硬件,应用程序一般是没法直接接触到“硬件”这一层的,实际上是操作系统抽象成“文件”这样的概念,程序操作的是文件,文件实际上是存储在硬盘上的。每个进程就会有一个“文件描述符表”来记录,当前这个进程正在使用哪些文件,操作系统打开一个文件,就会产生一个“文件描述符”(就像文件的身份标识一样,当然,只在进程内部产生),同时会使用文件描述符(类似于数组),把文件描述符给组织起来CPU. 进程是需要在CPU上来执行指令的早期的CPU都是单核心的,但算力不够就变成多核心了进程的调度:
  1. 并行:同一时刻,两个进程,同时运行在两个 cpu 逻辑核心上
  2. 并发:两个进程,在同一个舞台上,轮着上。由于CPU切换进程速度极快,微观上,这俩进程是串行执行的;宏观上,看起来这俩进程就是“同时”执行的
  3. 操作系统在调度这些进程时,两种都有可能
  4. 在应用程序这一层是感知不到的(在系统内核中感知到)。由于感知不到,通常用“并发”代指“并行”和“并发”
  1. PCB中关于进程调度相关的属性(这些属性也就描述了进程对应的 cpu 资源的使用情况)
  1. 状态
    就绪状态:一个进程已经随时做好了在CPU上执行的准备
    阻塞状态/睡眠状态:进程没有准备好被调度到CPU上
    实际上,进程在系统中状态还有很多种,其中最最关键的就是 就绪 和 阻塞 状态
  2. 优先级:系统给进程进行调度的时候,也不是完全公平的,也会根据优先级的不同,来决定时间分配的权衡就可以把系统资源调配给更重要的进程上了
  3. 上下文:这些进程是轮着上的,一次运行不完。就需要保证下次上 cpu 运行的时候,能够从上次运行到的位置,继续往后运行
    对于操作系统来说所记录的上下文,就是该进程在执行过程中,CPU的寄存器中对应的数据
    存档 读档
  4. 记账信息:相当于是一个统计信息,会统计每个进程在 cpu 上都执行了多久了,执行了多少指令了,是对于进程的调度工作进行一个“兜底“

每个进程有需要有一定的内存资源

虚拟地址空间的加持下 =>进程就具有了"独立性”=>每进程有自己的虚拟地址空间 =>一个进程无法直接访问或者修改其他进程虚拟地址空间的内容=>强化了系统稳定性

通过虚拟地址空间,把进程隔离开了,但是有时候,还需要让进程之间,产生点配合/联系

进程间通信:就是在进程隔离性的基础上,开个口子,能够有限制的进行相互影响

多进程已经很好的实现了并发编程的效果了,但是有明显的缺点:

  1. 消耗资源更多
  2. 速度更慢
相关文章
|
5天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
11天前
|
JSON Java Apache
非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程
UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。
|
4天前
|
Java 开发者
Java多线程编程的艺术与实践####
本文深入探讨了Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的技术文档,本文以实战为导向,通过生动的实例和详尽的代码解析,引领读者领略多线程编程的魅力,掌握其在提升应用性能、优化资源利用方面的关键作用。无论你是Java初学者还是有一定经验的开发者,本文都将为你打开多线程编程的新视角。 ####
|
3天前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
6天前
|
安全 Java 开发者
Java多线程编程中的常见问题与解决方案
本文深入探讨了Java多线程编程中常见的问题,包括线程安全问题、死锁、竞态条件等,并提供了相应的解决策略。文章首先介绍了多线程的基础知识,随后详细分析了每个问题的产生原因和典型场景,最后提出了实用的解决方案,旨在帮助开发者提高多线程程序的稳定性和性能。
|
9天前
|
监控 安全 Java
Java中的多线程编程:从入门到实践####
本文将深入浅出地探讨Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的摘要形式,本文将以一个简短的代码示例作为开篇,直接展示多线程的魅力,随后再详细解析其背后的原理与实现方式,旨在帮助读者快速理解并掌握Java多线程编程的基本技能。 ```java // 简单的多线程示例:创建两个线程,分别打印不同的消息 public class SimpleMultithreading { public static void main(String[] args) { Thread thread1 = new Thread(() -> System.out.prin
|
11天前
|
存储 缓存 安全
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见。本文介绍了使用 `File.createTempFile` 方法和自定义创建临时文件的两种方式,详细探讨了它们的使用场景和注意事项,包括数据缓存、文件上传下载和日志记录等。强调了清理临时文件、确保文件名唯一性和合理设置文件权限的重要性。
29 2
|
Java API 调度
Java调度框架Quartz 2.2.1
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/18792129 Java调度框架Quartz 2.2.1 Java调度框架Quartz 2.2.1版在前不久发布了,Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的日程序表。
865 0
|
13天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
4天前
|
安全 Java 开发者
Java 多线程并发控制:深入理解与实战应用
《Java多线程并发控制:深入理解与实战应用》一书详细解析了Java多线程编程的核心概念、并发控制技术及其实战技巧,适合Java开发者深入学习和实践参考。
下一篇
无影云桌面