当前位置: 首页 > news >正文

0802|IO进程线程 day5 进程概念

一、进程的基础

1.1 什么是进程

1)进程程序一次执行过程

  • 程序:是静态的,它是存储在外存上的可执行二进制文件;
  • 进程:动态的概念,它是程序的一次执行过程,包括了进程的创建,调度、消亡,是存在于内存中的。

2)进程是独立的,可以被CPU调度的任务

  • Linux中的调度机制:时间片轮询机制;
  • 操作系统会给每一个进程分配时间片,当时间片结束后,cpu资源会切走,当前进程等待下一次调度。

3)进程在被调度的时候,系统会分配和释放各种资源(CPU资源,内存资源,进程调度块(PCB))。

1.2 进程的五种状态及五态图

五种状态:

  1. 创建态
  2. 就绪态
  3. 运行态
  4. 阻塞态
  5. 终止态

ps:进程运行过程中有5种种状态,运行态只是进程运行过程中的一种状态。

五态图:

1.3 进程的内存分布【重点】

1)内存分布

  1. 在Linux操作系统中,每个进程都会被分配4G的内存空间(虚拟内存);
  2. 其中0-3G是用户空间代码使用,每个进程相互独立;
  3. 其中3-4G是内核空间,所有进程共享。

每个进程的用户空间都有自己独立的区:

1> 静态存储区 2> 堆区 3> 栈区

2)虚拟内存和物理内存

虚拟内存和物理内存之间的关系--->映射关系

物理内存:

  • 硬件上(内存条上)真正存在的存储空间。

虚拟内存:

  • 程序启动后,会分配4G的虚拟地址空间,用户只能访问到虚拟地址空间。当要使用的时候,由虚拟地址映射到物理地址上。
  • 32位操作系统,指针变量的大小为4bytes,取值范围为[0, 2^32-1],所以寻址范围为4G
  • 64位操作系统,指针变量的大小为8bytes,只取了前48bit存储地址,所以寻址范围是256TB

虚拟内存的目的:

  • 动态分配内存。

 

1.4 进程是资源分配的最小单位【重点】

以进程为单位分配和释放各种资源。

  1. 内存资源的申请和释放;
  2. 文件描述符表:每个进程都有自己的1024个文件描述符;
  3. 时间片;
  4. 管理自己的虚拟地址空间,使用的时候映射到物理地址上;

... ...

1.5 进程标识

操作系统会给每一个进程分配一个编号,这个编号就是进程号。

主要进程标识

  • 进程号:PID (process id)
  • 父进程号:PPID (parent process id)
  • 进程组号:PGID (process group id) 若干个进程的集合,称之为进程组,默认情况下新创建的进程会继承父进程的组ID
  • 会话组号:SID (session id) 若干个进程组的集合,称之为会话组,默认情况下新创建的进程会继承父进程的会话ID

操作系统刚启动的时候,会启动三个进程。三个特殊的进程号:

  • 0 idle进程 操作系统引导程序,创建1号,2号进程。
  • 1 init进程 初始化内核的各个模块,当内核启动完成后,用于收养孤儿进程(没有父进程的进程)
  • 2 kthreadd进程 用于进程间调度。

1.6 进程相关的shell指令

1) ps -aux

功能:显示进程占计算机资源的百分比;USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND

2) ps -ajx

功能:显示进程之间的关系PPID     PID    PGID    SID     TTY       TPGID STAT   UID   TIME COMMAND
父进程  进程号  进程组  会话组

3) pidof

功能:根据进程名字获取PID号;
格式:pidof a.out

4) pstree

功能:显示进程关系树

5) kill

kill -9  pid            根据pid号杀死进程
killall -9  进程名字    根据进程名字杀死进程

6) 进程的STAT

               D    不能被中断的阻塞状态R    运行状态S    可以被中断的阻塞状态T    被信号控制的挂起状态t    进程被调试的挂起状态X    死亡态,死亡是一瞬间的,该状态永远看不到Z    僵尸状态,当前进程退出后,父进程没有为其收尸。<    高优先级的N    低优先级的L    有些页被锁进内存s    会话组组长l    多线程+    运行在前端

http://www.lryc.cn/news/106190.html

相关文章:

  • 4 Promethues监控主机和容器
  • 亚马逊买家账号ip关联怎么处理
  • NO4 实验四:生成Web工程
  • 【linux】进程
  • 电商高并发设计之SpringBoot整合Redis实现布隆过滤器
  • SpringBoot第25讲:SpringBoot集成MySQL - MyBatis 注解方式
  • 服务器返回 413 Request Entity Too Large
  • 如何一目了然地监控远程 Linux 系统
  • 9.环境对象和回调函数
  • 51单片机(普中HC6800-EM3 V3.0)实验例程软件分析概览
  • ubuntu18.04 安装php7.4-xdebug
  • java 定时任务不按照规定时间执行
  • Android复习(Android基础-四大组件)—— Activity
  • Linux系统安装部署MongoDB完整教程(图文详解)
  • CSS图片放到<div>里面,自适应宽高全部显示,点击图片跳到新页面预览,点击旋转按钮图片可旋转
  • 二阶段web基础与http协议
  • SpringBoot+Freemark根据html模板动态导出PDF
  • XPath数据提取与贴吧爬虫应用示例
  • 字符串匹配-KMP算法
  • Java面向对象之UML类图
  • 【机器学习】西瓜书学习心得及课后习题参考答案—第4章决策树
  • 2023.8.2
  • windows运行窗口常用快捷键命令
  • HDFS的QJM方案
  • 安装win版本的neo4j(2023最新版本)
  • ChatGPT结合知识图谱构建医疗问答应用 (二) - 构建问答流程
  • 聊天系统登录后端实现
  • Ajax笔记_01(知识点、包含代码和详细解析)
  • Eureka 学习笔记2:EurekaClient
  • Spring引入并启用log4j日志框架-----Spring框架