<JavaEE> 什么是进程(Process)?进程管理,进程调度,内存管理,进程间通信和多进程编程

news2025/1/11 14:06:41

目录

一、进程(Process)的概念

二、进程管理

三、进程调度

四、内存管理

五、进程间通信

六、多进程编程


一、进程(Process)的概念

        进程(process)也称为任务(task),是操作系统对一个正在运行的程序的一种抽象,可以把进程看作程序的一次运行过程。同时,在操作系统内部,每个进程在执行过程中,都需要消耗一定的软件和硬件资源,因此进程又是操作系统进行资源分配的基本单位。


二、进程管理

描述进程:

        进程使用进程控制块(PCB)进行描述,计算机内部要管理任何现实事物,都需要将其抽象成一组有关联的、互为一体的数据。

        在不同语言中,可以使用类或结构体的方式来描述事物的特征

        每一个进程控制块(PCB)对象,就代表一个运行着的程序,即进程。

阅读指针 -> 《什么是进程控制块(PCB Process Control Block)?》

<JavaEE> 什么是进程控制块(PCB Process Control Block)?-CSDN博客文章浏览阅读16次。介绍进程控制块和进程控制块的核心属性。进程控制块适用于进程,也适用于线程。https://blog.csdn.net/zzy734437202/article/details/134583750

组织进程:

        操作系统通过线性表、搜索树等数据结构将进程控制块(PCB)进行组织,方便管理时进行增删改查操作。


三、进程调度

        进程调度(Process Scheduling),是对CPU资源进行分配。

        同一时刻,一个CPU核心上,只能有一个进程在运行。但CPU核心少,进程往往非常多,CPU资源不够分配。此时就需要进行进程调度,分时复用,并发执行

        操作系统对CPU资源的分配,采用的时时间模式,即不同的进程在不同的时间段使用CPU资源。


四、内存管理

        内存管理(Memory Manage)也称为内存分配。每个进程的内存是彼此独立,互不干扰的,这也体现了进程的“独立性”。

        进程运行过程中被切换出CPU,此时其消耗的内存空间将暂时存放至硬盘的特定区域(swap空间),直到进程真正执行,

        操作系统对内存资源的分配,采用的是空间模式,即不同进程使用内存中的不同区域,互相之间不会干扰。


五、进程间通信

        进程是操作系统进行资源分配的最小单位,而且进程间具有“独立性”,但有时也需要多个进程之间配合完成某些任务,这就需要系统提供一些公共空间,让多个进程都能访问,进程之间借助公共空间进行数据交互,这就被称为进程间通信(Inter Process Communication)

        主流操作系统提供的进程通信机制包括:管道、共享内存、文件、网络、信号量、信号等。


六、多进程编程

简述并发的概念:

        并发(Concurrency)是一种在同一时间执行多个任务的技术。在计算机领域中,并发通常通过多线程或多进程来实现。多线程可以让程序同时执行多个任务,而多进程则可以让程序同时执行多个独立的程序。

        多个进程在同一个CPU中依次切换执行,当切换速度足够快时,在人的感知中,这些进程就是同时在执行的,这就被称为“并行”。

        当多个进程在多个CPU中依次切换执行时,从微观上看来,这些进程就不再是“依次执行”,而是“同时执行”,这就被称为“并发”。

        在多核CPU中,并行和并发是同时出现的,因此,往往也将并行和并发统称为并发,与之对应的编程方式就称为并发编程。

多进程编程的缺点:

        进程通常可以很好的解决“并发编程”的问题,但在需要频繁创建和销毁进程得情况下,进程表现得不尽如人意。此时使用的多进程编程,会使得系统开销过大。

        系统开销过大的原因在于,进程是操作系统进行资源分配的基本单位,每次创建或销毁进程都需要申请或释放系统资源。

        总结,进程过于“笨重”,在频繁进行创建和销毁时,需要不断地向系统申请和释放资源,开销较大


阅读指针 -> 《什么是线程(Thread)?进程和线程有什么区别?》

<JavaEE> 什么是线程(Thread)?进程和线程有什么区别?-CSDN博客介绍什么是线程(Thread)。进程和线程有什么区别.https://blog.csdn.net/zzy734437202/article/details/134589609

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

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

相关文章

sam和mobilesam的c#调用dll

这个主要注意: 我原本从一个地方把这个工程拷贝到另一个地方,然后我看了解决方案下的依赖项是有感叹号的,且这个时候代码出现很多下划的波浪红线。 然后我的做法如下: 然后我发现一直添加不了opencvsharp的dll文件,报…

Adiponectin 脂联素 ; T-cadherin +exosome

T-cadherin Adiponectin exosome T-cadherin Adiponectin exosome 代谢综合征中 外泌体、脂肪组织 和 脂联素 的器官间通讯-2019.pdf

基于IDEA+HTML+SpringBoot前后端分离电子商城

基于springboot的电子商城 项目介绍💁🏻 •B2C 商家对客户 •C2B2C 客户对商家对客户 1.1.1 B2C 平台运营方即商品的卖家 小米商城 •商品 •用户 1.1.2 C2B2C 平台运营方不卖商品(也可以卖) 卖家是平台的用户 买家也是平台用户 •…

HarmonyOS(五)—— 认识页面和自定义组件生命周期

前言 在前面我们通过如何创建自定义组件一文知道了如何如何自定义组件以及自定义组件的相关注意事项,接下来我们认识一下页面和自定义组件生命周期。 自定义组件和页面的关系 在开始之前,我们先明确自定义组件和页面的关系 自定义组件:Co…

基于C#实现线段树

一、线段树 线段树又称"区间树”,在每个节点上保存一个区间,当然区间的划分采用折半的思想,叶子节点只保存一个值,也叫单元节点,所以最终的构造就是一个平衡的二叉树,拥有 CURD 的 O(lgN)的时间。 从…

解决:javax.websocket.server.ServerContainer not available 报错问题

原因: 用于扫描带有 ServerEndpoint 的注解成为 websocket,该方法是 服务器端点出口,当进行 SpringBoot 单元测试时,并没有启动服务器,所以当加载到这个bean时会报错。 解决方法: 加上这个注解内容 Spr…

不做机器视觉工程师,转行,转岗的建议与想法

正所谓外行看热闹,内行看门道。提前咨询前辈们,多问问,多看看。要做就做,一定要提前做好防范。 无论你是要转行或者是转岗,看你有没有本钱和试错成本 有些人,家庭好,可以一直去试错和从头再来。…

MySQL 8 配置文件详解与最佳实践

MySQL 8 是一款强大的关系型数据库管理系统,通过适当的配置文件设置,可以充分发挥其性能潜力。在这篇博客中,我们将深入探究 MySQL 8 常用的配置文件,并提供一些建议,帮助您优化数据库性能。 配置文件概览 在 MySQL …

4.常见面试题--操作系统

特点:并发性、共享性、虚拟性、异步性。 Windows 和 Linux 内核差异 对于内核的架构⼀般有这三种类型: ● 宏内核,包含多个模块,整个内核像⼀个完整的程序; ● 微内核,有⼀个最⼩版本的内核&#xff0…

linux的基础命令

文章目录 linux的基础命令一、linux的目录结构(一)Linux路径的描述方式 二、Linux命令入门(一)Linux命令基础格式 三、ls命令(一)HOME目录和工作目录(二)ls命令的参数1.ls命令的-a选…

Java项目如何打包成Jar(最简单)

最简单的办法,使用Maven插件(idea自带) 1.选择需要打包的mudule,点击idea右侧的maven插件 2.clean操作 3.选择需要的其他mudule,进行install操作(如果有) 4.再次选择需要打包的module&#…

UDP客户端使用connect与UDP服务器使用send函数和recv函数收发数据

服务器代码编译运行 服务器udpconnectToServer.c的代码如下&#xff1a; #include<stdio.h> #include<stdlib.h> #include<string.h> #include<unistd.h> #include<arpa/inet.h> #include<sys/socket.h> #include<errno.h> #inclu…

什么是网络爬虫技术?它的重要用途有哪些?

网络爬虫&#xff08;Web Crawler&#xff09;是一种自动化的网页浏览程序&#xff0c;能够根据一定的规则和算法&#xff0c;从互联网上抓取和收集数据。网络爬虫技术是随着互联网的发展而逐渐成熟的一种技术&#xff0c;它在搜索引擎、数据挖掘、信息处理等领域发挥着越来越重…

CentOS Stream 9系统Cgroup问题处理

安装docker容器启动失败 之前适配过Ubuntu系统的容器&#xff0c;由于版本比较高&#xff0c;没有挂载Cgroup的路径。这次使用Centos Stream 9系统安装docker容器时也遇到了这个情况。由于处理方式有些不一样&#xff0c;所以记录一下。 这是docker容器启动过报错的输出日志。…

C#串口通信从入门到精通(27)——高速通信下解决数据处理慢的问题(20ms以内)

前言 我们在开发串口通信程序时,有时候会遇到比如单片机或者传感器发送的数据速度特别快,比如10ms、20ms发送一次,并且每次发送的数据量还比较大,如果按照常规的写法,我们会发现接收的数据还没处理完,新的数据又发送过来了,这就会导致处理数据滞后,软件始终处理的不是…

5G智慧工地整体解决方案:文件全文115页,附下载

关键词&#xff1a;5G智慧工地&#xff0c;智慧工地建设方案&#xff0c;智慧工地管理平台系统&#xff0c;智慧工地建设调研报告&#xff0c;智慧工地云平台建设 一、5G智慧工地建设背景 5G智慧工地是利用5G技术、物联网、大数据、云计算、AI等信息技术&#xff0c;围绕“人…

docker 安装常用环境

一、 安装linux&#xff08;完整&#xff09; 目前为止docker hub 还是被封着&#xff0c;用阿里云、腾讯云镜像找一找版本直接查就行 默认使用latest最新版 #:latest 可以不写 docker pull centos:latest # 拉取后查看 images docker images #给镜像设置标签 # docker tag […

pytorch训练模型内存溢出

1、训练模型命令命令 如下所示是训练命名实体识别的命令&#xff0c;在win10系统下执行 activate pytorch cd F:\Python\github\ultralytics-main\submain\pytorch_bert_bilstm_crf_ner-main f: python main.py --bert_dir"../model_hub/chinese-bert-wwm-ext/" --…

【Fusion 360环境搭建】保姆级贴心教程

文章目录 选择Fusion 360的理由一、Fusion 360注册账号二、安装 选择Fusion 360的理由 稚辉君推荐&#xff01; 一、Fusion 360注册账号 官网网址 https://www.autodesk.com.cn/products/fusion-360 贴心提示&#xff1a;访问不了时试试手机热点 选择“ 教育” &#xf…

【Java】初识JDBC

&#x1f33a;个人主页&#xff1a;Dawn黎明开始 &#x1f380;系列专栏&#xff1a;Java ⭐每日一句&#xff1a;向阳而生&#xff0c;逐光而行 &#x1f4e2;欢迎大家&#xff1a;关注&#x1f50d;点赞&#x1f44d;评论&#x1f4dd;收藏⭐️ 文章目录 &#x1f4cb;前言 …