【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. 速度更慢
目录
打赏
0
0
0
0
9
分享
相关文章
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
java并发编程中Monitor里的waitSet和EntryList都是做什么的
在Java并发编程中,Monitor内部包含两个重要队列:等待集(Wait Set)和入口列表(Entry List)。Wait Set用于线程的条件等待和协作,线程调用`wait()`后进入此集合,通过`notify()`或`notifyAll()`唤醒。Entry List则管理锁的竞争,未能获取锁的线程在此排队,等待锁释放后重新竞争。理解两者区别有助于设计高效的多线程程序。 - **Wait Set**:线程调用`wait()`后进入,等待条件满足被唤醒,需重新竞争锁。 - **Entry List**:多个线程竞争锁时,未获锁的线程在此排队,等待锁释放后获取锁继续执行。
90 12
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
123 13
|
2月前
|
Java多线程编程秘籍:各种方案一网打尽,不要错过!
Java 中实现多线程的方式主要有四种:继承 Thread 类、实现 Runnable 接口、实现 Callable 接口和使用线程池。每种方式各有优缺点,适用于不同的场景。继承 Thread 类最简单,实现 Runnable 接口更灵活,Callable 接口支持返回结果,线程池则便于管理和复用线程。实际应用中可根据需求选择合适的方式。此外,还介绍了多线程相关的常见面试问题及答案,涵盖线程概念、线程安全、线程池等知识点。
236 2
如何找出Java进程占用CPU高的元凶
本文记录了一次Java进程CPU占用率过高的问题和排查思路。
Java多线程编程中的陷阱与最佳实践####
本文探讨了Java多线程编程中常见的陷阱,并介绍了如何通过最佳实践来避免这些问题。我们将从基础概念入手,逐步深入到具体的代码示例,帮助开发者更好地理解和应用多线程技术。无论是初学者还是有经验的开发者,都能从中获得有价值的见解和建议。 ####
|
2月前
|
Java中的多线程编程与并发控制
本文深入探讨了Java编程语言中多线程编程的基础知识和并发控制机制。文章首先介绍了多线程的基本概念,包括线程的定义、生命周期以及在Java中创建和管理线程的方法。接着,详细讲解了Java提供的同步机制,如synchronized关键字、wait()和notify()方法等,以及如何通过这些机制实现线程间的协调与通信。最后,本文还讨论了一些常见的并发问题,例如死锁、竞态条件等,并提供了相应的解决策略。
76 3
[JavaEE]———进程、进程的数据结构、进程的调度
操作系统,进程任务,PCB,PID,内存指针,文件描述符表,进程的调度,并发编程,状态,优先级,记账信息,上下文
Java基础知识之典型范例(一)
Java基础知识之典型范例(一)
135 0

热门文章

最新文章