【进程概念】

目录

  • 什么是在计算机运行的程序
  • 这么多运行的程序计算机是如何管理的
    • 先描述
    • 再组织

什么是在计算机运行的程序

对于一个在磁盘可执行的二进制文件,也可叫做可执行程序。对于一个可执行的程序,程序有自己的代码和数据。一旦运行起来,就会在计算机内部运作起来。
根据冯诺依曼体系,一个程序要被运行起来,先是要加载到内存当中,然后再到CPU调度。当代计算机中,能运行一个程序,就能运行多个程序,然后每个二进制的可执行文件程序都像在自己干自己的事情,互不干扰。这就是在计算机运行的程序。

这么多运行的程序计算机是如何管理的

先描述

当程序加载到内存的时候,计算机的操纵系统(OS)必然会对这个程序进行管理,操作系统是通过对程序对象的先描述,抽象成一个对象,这个概念就是进程(process),所以程序运行起来就是操作系统的一个进程(操作系统创建一个进程来运行这个程序)。操作系统对程序的管理转而变为对进程的管理,进程有程序的代码和数据。实际上在磁盘的程序在运行之前,是把代码和数据拷贝到内存当中,而程序依据再磁盘保存着,所以说运行的程序其实是操作系统中运行的进程。然后这些进程在合适的时机会被CPU调度。

再组织

对程序拷贝到内存的代码和数据进行描述完成后,操作系统要对这些进程管理,再linux系统当中,会以一个叫task_struct的结构体对象对进程进行管理,task_struct包含着进程的属性,task_struct就是操作系统管理进程的控制块(process contorl block),然后task_struct以某种数据结构类型相互联系起来。再以一个struct runqueue的运行队列结构体管理。
进程包含(代码 + 数据 + 进程控制数据结构)
如果一个在磁盘可执行的文件已经加载到内存有进程一直在运行,如果进程还没结束,把磁盘的可执行文件删除,该进程还能运行,因为该进程是拷贝可执行文件的数据和代码,虽然已经删除可执行文件,但依旧运行。如果终止想重新执行就不可以。

struct task_struct {volatile long state;	/* -1 unrunnable, 0 runnable, >0 stopped */prio_array_t *array;//有该进程被cpu调度的优先级pid_t pid;//有进程的id编号pid_t tgid;struct mm_struct *mm, *active_mm;//进程的内存地址空间int exit_code, exit_signal;//进程的退出码和退出信息struct task_struct *next_task, *prev_task;////...........................................//该进程的一系列属性。包括形成该进程的文件路径和其他文件信息
}
//操作系统也是软件,上述结构体就是操作系统管理进程的task_struct
struct task_struct *next_task, *prev_task;

操作系统通过这种双链表的形式组织管理这些进程控制块。
在这里插入图片描述

当新的程序执行的时候,操作系统再次创建进程,把进程通过链表的链入规则连接到运行队列,如果进程结束,则task_struct在链表上删除,然后重新连接。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【无标题】学习Markdown

https://shadows.brumm.af 欢迎使用Markdown编辑器 你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。 新的改变 我们对Markdown编辑器进行了一些…

2.22 作业

顺序表 运行结果 fun.c #include "fun.h" seq_p create_seq_list() {seq_p L (seq_p)malloc(sizeof(seq_list));if(LNULL){printf("空间申请失败\n");return NULL;}L->len 0; bzero(L,sizeof(L->data)); return L; } int seq_empty(seq_p L) {i…

LaWGPT—基于中文法律知识的大模型

文章目录 LaWGPT:基于中文法律知识的大语言模型数据构建模型及训练步骤两个阶段二次训练流程指令精调步骤计算资源 项目结构模型部署及推理 LawGPT_zh:中文法律大模型(獬豸)数据构建知识问答模型推理训练步骤 LaWGPT:基…

深入理解C语言(5):程序环境和预处理详解

文章主题:程序环境和预处理详解🌏所属专栏:深入理解C语言📔作者简介:更新有关深入理解C语言知识的博主一枚,记录分享自己对C语言的深入解读。😆个人主页:[₽]的个人主页&#x1f3c4…

【MySQL】数据库索引详解 | 聚簇索引 | 最左匹配原则 | 索引的优缺点

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; &#x1f525;c系列专栏&#xff1a;C/C零基础到精通 &#x1f525; 给大…

mysql 2-22

变量 查看系统变量 修改 用户变量 赋值 定义处理程序 流程控制 IF CASE LOOP语句 WHILE循环 REPEAT leave ITERATE 游标 使用步骤 全局系统变量持久化 触发器 查看触发器 优点 MYSQL8的新特性 移除的旧特性 窗口函数 公用表表达式 JDBC 存储引擎 MYISAM存储引擎 InnoDB存储引擎…

【Redis】理论进阶篇------浅谈Redis的缓存穿透和雪崩原理

一、缓存穿透 1、概念 缓存穿透&#xff08;查不到数据&#xff09;&#xff0c;是指当用户想要查询数据的时候&#xff0c;会先去Redis中取命中&#xff0c;如果Redis中没有该数据&#xff0c;那么就会向数据库中去查找数据。如果数据库中也没有&#xff0c;则该次查询结果失…

Linux之信号

首先我们来了解一下信号的概念! 我们可以以上红框中的4个特点。 进程分为前台和后台进程,前台进程只有一个,后台进程可以有多个!(并且后台进程不能用ctrl+c中止,只能用kill -9去杀掉) jobs可以看作业标识号! (ctrl+z可以暂停进程,不能暂停前台进程,如果暂停就会被…

Eclipse中Working Sets是用来做什么的?

当Eclipse中创建了太多的project&#xff0c;太多了&#xff0c;看的眼花缭乱&#xff0c;不好管理,也不想更换工作空间&#xff0c;Eclipse中 Java Working Set 工作集&#xff0c;可以将这些project分组&#xff0c;就像文件夹分类存放文件一样。 多说一句&#xff0c;感觉E…

C++ Primer 笔记(总结,摘要,概括)——第2章 变量和基本类型

目录 2.1 基本内置变量 2.1.1 算术类型 2.1.2 类型转换 2.1.3 字面值常量 2.2 变量 2.2.1 变量定义 2.2.2 变量声明和定义的关系 2.2.3 标识符 2.2.4 名字的作用域 2.3 复合类型 2.3.1 引用 2.3.2 指针 2.3.3 理解复合类型的声明 2.4 const限定符 2.4.1 const的引用 2.4.2…

【时事篇-05-03】20240222 金额145-150元填充27笔货币基金的具体数目测算( itertools)

作品展示 背景需求&#xff1a; 通过 itertools计算2525元存17笔145-150元金额的最适合方案 【时事篇-05-02】20240221 2525元存17只货币基金的具体数目测算&#xff08; itertools&#xff09;-CSDN博客文章浏览阅读823次&#xff0c;点赞32次&#xff0c;收藏13次。【时事篇…

陈世元:被保送中科院,两次被裁,人生不能老是按部就班的走下去,需要冒险,尝试一下新的东西

《程客有话说》是我们最新推出的一个访谈栏目&#xff0c;邀请了一些国内外有趣的程序员来分享他们的经验、观点与成长故事&#xff0c;我们尝试建立一个程序员交流与学习的平台&#xff0c;也欢迎大家推荐朋友或自己来参加我们的节目&#xff0c;一起加油。 本期我们邀请的程…