news 2026/4/13 17:47:36

程序与进程:解密运行背后的奥秘

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
程序与进程:解密运行背后的奥秘

进程与程序的核心概念

进程是程序执行的动态实例,包含内存分配、CPU调度等资源管理。程序是静态存储在硬盘上的代码和数据集合。

  • 区别
    • 程序永久存储,进程临时存在
    • 进程有状态变化(创建、运行、终止),程序无状态
    • 进程可并发执行,程序不可并发
    • 进程间竞争资源(CPU、内存)
    • 一个程序可生成多个进程,一个进程可执行多个程序

进程控制块(PCB)

PCB是操作系统描述进程的核心数据结构,包含以下信息:

  • PID:唯一进程标识符
  • 工作路径:进程当前目录(chdir相关)
  • umask:默认文件权限掩码(如0002
  • 文件列表:进程打开的文件描述符
  • 信号处理:异步I/O事件响应配置
  • 用户/组ID:权限控制标识
  • 资源限制:如最大打开文件数(默认1024)、栈大小(如8MB)

进程的内存与隔离性

  • 虚拟内存
    • 隔离性:进程间内存空间不可直接访问
    • 安全性:通过权限控制防止非法访问内核空间
  • 进程内存布局:包括代码段、数据段、堆、栈等

进程分类

  1. 交互式进程:需用户输入后输出(如命令行工具)
  2. 批处理进程:批量执行命令(如Shell脚本)
  3. 守护进程:后台自动运行,响应特定事件(如系统服务)

进程调度与并发

  • 调度算法
    • 时间片轮转:每个进程分配固定CPU时间
    • 短任务优先:优先执行耗时短的进程
    • CFS(完全公平调度):基于权重分配CPU时间
  • 并发本质
    • 宏观并行:多进程同时运行(时间段内)
    • 微观串行:任一时刻仅一个进程占用CPU

进程上下文切换

当CPU时间片耗尽时:

  1. 当前进程状态(PCB、寄存器值)保存到内存/硬盘
  2. 新进程状态从存储加载到内存
  3. CPU切换到新进程执行

Linux进程管理命令

  • ps aux:列出所有进程详细信息
  • top:动态查看进程资源占用
  • kill:发送信号控制进程
    • kill -9 PID:强制终止进程
    • killall -9 a.out:终止所有同名进程

进程创建函数(fork

pid_t fork(void);
  • 行为
    • 克隆父进程的地址空间和PCB,生成子进程
    • 子进程从fork()后开始执行,与父进程共享代码逻辑
  • 返回值
    • 父进程:返回子进程PID(>0)
    • 子进程:返回0
    • 失败:返回-1

获取进程ID的函数

pid_t getpid(void); // 获取当前进程PID pid_t getppid(void); // 获取父进程PID
  • 用途:明确进程关系,用于调试或资源管理

关键注意事项

  • 父子进程独立性:变量不共享,修改互不影响
  • 执行顺序:父子进程运行顺序由调度器决定,非固定
  • 资源释放:子进程终止后需由父进程回收(避免僵尸进程)

通过上述机制,操作系统实现多进程的高效管理和资源分配。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 14:40:13

基于固定旋转Gough-Stewart平台模型的六自由度调整数学模型设计与实现

5 固定旋转 Gough-Stewart 平台的数学模型,允许使用爱好伺服系统调整六个平行腿的长度,以实现平台的 6 自由度运动 该模型允许定义俯仰-横滚-偏航轨迹来模拟轨迹并确保伺服角度在允许的运动范围内模型经过参数化,允许用户定义基座和平台上的连…

作者头像 李华
网站建设 2026/4/7 8:18:09

Waymo数据集10Hz相机序列:时序分析中的关键挑战与突破

Waymo数据集10Hz相机序列:时序分析中的关键挑战与突破 【免费下载链接】waymo-open-dataset Waymo Open Dataset 项目地址: https://gitcode.com/gh_mirrors/wa/waymo-open-dataset Waymo Open Dataset作为自动驾驶领域的重要数据源,其端到端驾驶…

作者头像 李华
网站建设 2026/4/12 5:00:59

Intel Neural Compressor终极指南:掌握深度学习模型压缩技术

Intel Neural Compressor终极指南:掌握深度学习模型压缩技术 【免费下载链接】neural-compressor Provide unified APIs for SOTA model compression techniques, such as low precision (INT8/INT4/FP4/NF4) quantization, sparsity, pruning, and knowledge disti…

作者头像 李华
网站建设 2026/4/10 2:02:17

局域网服务发现技术:mDNS与DNS-SD实战

本文深入解析mDNS和DNS-SD协议原理,带你实现零配置的局域网服务自动发现。 前言 你有没有好奇过: 为什么iPhone能自动发现家里的AirPlay设备? 为什么Chromecast能被同一WiFi下的设备识别? 为什么NAS可以在文件管理器中自动显示? 这背后都是同一套技术:mDNS + DNS-SD,也…

作者头像 李华
网站建设 2026/4/13 15:17:29

kcat工具实战:3分钟构建企业级Kafka内存测试环境

kcat工具实战:3分钟构建企业级Kafka内存测试环境 【免费下载链接】kcat Generic command line non-JVM Apache Kafka producer and consumer 项目地址: https://gitcode.com/gh_mirrors/kc/kcat 在当今微服务架构盛行的时代,Kafka已成为消息系统的…

作者头像 李华