【进程与线程】进程的PID

什么是 PID?

PID(Process Identifier,进程标识符)是操作系统为每个进程分配的一个唯一标识,用于标识系统中的每个进程。PID 是一个非负整数,通常从 1 开始分配;每个运行中的进程都有一个唯一的 PID,通过 PID,操作系统可以区分不同的进程并对它们进行管理。

简单点理解为 操作系统为进程分配的身份证号。


PID 的作用

  1. PID 是进程的唯一标识,操作系统通过 PID 来区分和管理进程;用户和管理员可以通过 PID 操作特定的进程(如通过 kill 命令终止进程)。
  2. 用于进程间通信:一些进程间通信(如信号传递)需要使用 PID 确定目标进程。
  3. 系统调试与监控:系统管理员或开发者可以通过 PID 来监控进程的状态(如 CPU 使用率、内存占用等)。

PID是唯一标识进程,帮助操作系统管理和调度进程,在开发中,PID 被广泛用于进程间通信、调试、监控和操作系统管理。


PID 的分配

操作系统在创建进程时,为每个进程分配一个唯一的 PID。
PID分配规则:顺序分配 —> PID 的分配通常是递增的,但当最大值达到后,会从最小值重新分配未使用的 PID。

常见的 PID 分配范围

Linux/Unix 系统:PID 的默认范围是 1 到 32768(可以通过修改 /proc/sys/kernel/pid_max 调整最大值,例如扩展到 4194304)。
Windows 系统:PID 通常为一个 32 位整数。

特殊的 PID
  • PID 0:表示内核调度程序(不是普通进程)。
  • PID 1:表示 init 进程(Linux/Unix 系统中的第一个用户态进程,负责启动其他进程)。
  • PID 2~N:用于其他系统进程和用户进程。

获取 PID 的方法

(1)在程序中获取当前进程的 PID(Unix/Linux 系统):
C:

#include <unistd.h>
#include <stdio.h>int main() {pid_t pid = getpid();  // 获取当前进程的 PIDprintf("Current PID: %d\n", pid);return 0;
}

Python:

import os
print(f"Current PID: {os.getpid()}")

(2)通过命令获取进程的 PID
使用 ps 命令:

ps -e    # 显示所有进程及其 PID
ps -ef   # 显示详细的进程信息
ps -aux  # 显示所有进程的详细信息

使用 tophtop:通过实时监控工具查看正在运行的进程及其 PID。
使用 pidof 命令:

pidof <进程名>   # 获取指定进程的 PID

与 PID 相关的系统调用

(1)获取当前进程的 PID
使用 getpid() 系统调用。在 Linux/Unix 系统中,用于获取当前进程的 PID。
(2)获取父进程的 PID
使用 getppid() 系统调用。用于获取当前进程的父进程的 PID。
(3)创建子进程
使用 fork() 系统调用(Linux/Unix 系统)。父进程调用 fork() 后,会创建一个子进程,父进程的 fork() 返回子进程的 PID,而子进程的 fork() 返回 0。

#include <stdio.h>
#include <unistd.h>int main() {pid_t pid = fork();if (pid == 0) {// 子进程printf("This is child process. PID: %d, Parent PID: %d\n", getpid(), getppid());} else if (pid > 0) {// 父进程printf("This is parent process. PID: %d, Child PID: %d\n", getpid(), pid);} else {// fork 失败perror("fork failed");}return 0;
}

PID 的回收机制

当进程终止时,其 PID 会被系统回收;回收的 PID 会重新分配给新的进程。系统会确保在一段时间内不会重复使用同一个 PID,以避免 PID 冲突。

僵尸进程与 PID 回收

如果一个子进程终止后,父进程没有调用 wait()waitpid() 获取其退出状态,子进程会进入僵尸状态。
僵尸进程虽然释放了资源,但其 PID 不会被系统回收,直到父进程清理该子进程。

注意事项
  1. PID 不保证连续性:PID 是唯一的,但不连续。由于进程的创建和退出,PID 可能会跳跃。
  2. PID 的最大值限制:Linux 系统中,PID 的最大值可通过 /proc/sys/kernel/pid_max 查看或修改:
cat /proc/sys/kernel/pid_max  # 查看 PID 最大值
echo 4194304 > /proc/sys/kernel/pid_max  # 修改最大值
  1. PID 冲突问题:当系统中进程数量非常多且 PID 最大值较小时,可能会导致 PID 重复分配的风险。

综上,PID 是操作系统中进程管理的核心抽象,它通过唯一标识的方式为操作系统提供了一种高效、简单的进程区分机制。操作系统通过 PID 实现进程的生命周期管理(创建、运行、终止)和资源分配。PID 是进程间通信和信号传递的重要桥梁(如 kill 命令通过 PID 发送信号)。

在实际开发中,系统管理员和开发者通过 PID 进行进程监控、调试、优化和故障处理。

以上。仅供学习与分享交流,请勿用于商业用途!转载需提前说明。

我是一个十分热爱技术的程序员,希望这篇文章能够对您有帮助,也希望认识更多热爱程序开发的小伙伴。
感谢!

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

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

相关文章

学习python类的总结

前言 之前天天看到有人用类相关的知识但是学校老师就是没讲过&#xff0c;然后再读了莫烦老师的讲解后&#xff0c;有了一定的了解&#xff0c;进行一个总结。 正文 类的意义 类其实就是正如他的名字一样&#xff0c;是一类事物&#xff08;其实叫做对象&#xff09;的总称…

JavaSE学习心得(多线程与网络编程篇)

多线程-网络编程 前言 多线程&JUC 多线程三种实现方式 第一种实现方式 第二种实现方式 第三种实现方式 常见成员方法 买票引发的安全问题 同步代码块 同步方法 Lock锁 生产者和消费者 常见方法 等待唤醒机制 练习 抢红包 抽奖 多线程统计并求最…

Pytorch基础教程:从零实现手写数字分类

文章目录 1.Pytorch简介2.理解tensor2.1 一维矩阵2.2 二维矩阵2.3 三维矩阵 3.创建tensor3.1 你可以直接从一个Python列表或NumPy数组创建一个tensor&#xff1a;3.2 创建特定形状的tensor3.3 创建三维tensor3.4 使用随机数填充tensor3.5 指定tensor的数据类型 4.tensor基本运算…

candb++ windows11运行报错,找不到mfc140.dll

解决问题记录 mfc140.dll下载 注意&#xff1a;放置位置别搞错了

​公专网一体5G工业路由器,智慧电网全链路加密监控管理

随着可再生能源的集成 电网调度策略复杂性增加 需更精细的并网管理以平衡供需 传统电力网络的通信基础落后 难以适应电力设施的广泛分布 和日益增长的管理维护需求 计讯物联5G公专网一体路由器 通过融合公网和专网的优势 有效解决了现代电网对于 高效、灵活和安全通信的需求 ↓…

【Linux】--- 进程的等待与替换

进程的等待与替换 一、进程等待1、进程等待的必要性2、获取子进程status3、进程等待的方法&#xff08;1&#xff09;wait&#xff08;&#xff09;函数&#xff08;2&#xff09;waitpid函数 4、多进程创建以及等待的代码模型5、非阻塞接口 轮询 二、进程替换1、替换原理2、替…

intel x99主板设置上电服务器自动启动

作者&#xff1a;吴业亮 博客&#xff1a;wuyeliang.blog.csdn.net 1、选择IntelRCStetup–>PCH state after G3 -->ON PCH state after G3&#xff1a;是指系统完全关闭电源的状态&#xff0c;此时主板上只有RTC&#xff08;实时时钟&#xff09;电源。这个选项决定了系…

机器学习-归一化,标准化

标准化&#xff08;Standardization&#xff09;是将数据按比例缩放&#xff0c;使其具有特定的统计特征&#xff0c;通常是将数据的均值调整为0&#xff0c;标准差调整为1。标准化是一种常见的数据预处理技术&#xff0c;特别是在进行机器学习时&#xff0c;通常会使用标准化来…

zerotier搭建虚拟局域网,自建planet

基于该开源项目 自建planet节点&#xff0c;更快速&#xff0c;更安全 本教程依据docker-zerotier-planet 项目文档书写&#xff0c;并以linux(centos 7)和windows作为示例&#xff0c;需要其他系统配置方法&#xff0c;可移步项目文档 一. 前置资源 具有外网ip的服务器 后面…

Spring Boot + MyBatis-Flex 配置 ProxySQL 的完整指南

✅ Spring Boot MyBatis-Flex 配置 ProxySQL 的完整指南 下面是一个详细的教程&#xff0c;指导您如何在 Spring Boot 项目中使用 MyBatis-Flex 配置 ProxySQL 进行 读写分离 和 主从同步 的数据库访问。 &#x1f3af; 目标 在 Spring Boot 中连接 ProxySQL。使用 MyBatis-…

如何解决Webview和H5缓存问题,确保每次加载最新版本的资源

WebView 用于加载 H5 页面是常见的做法&#xff0c;它能够加载远程的 HTML、CSS、JavaScript 资源&#xff0c;并且让 Web 应用嵌入到原生 App 中。然而&#xff0c;WebView 的缓存机制有时会导致用户看到的是旧版本的页面或资源&#xff0c;尤其是在 H5 发版后&#xff0c;iOS…

屏幕轻触间:触摸交互从 “感知” 到 “智算” 的隐秘路径

从用户点击屏幕到前端感知及数据处理全流程剖析 引言 在移动智能设备与触摸交互技术深度融合的当下&#xff0c;当我们的手指轻触手机屏幕&#xff0c;一系列复杂且精妙的技术流程便瞬间启动。这一过程涵盖硬件层、驱动层、操作系统层、应用层&#xff0c;甚至延伸到后端的数…

微调的种类

微调的种类 flyfish 全参数微调&#xff08;Full Fine-Tuning&#xff09;&#xff1a; 对预训练模型的所有参数进行调整&#xff0c;以优化其在特定任务上的性能。 指令微调&#xff08;Instruction Fine-Tuning&#xff09;&#xff1a; 通过提供特定任务的明确指令或示例来…

C# 配置文件:app.config 和 web.config

一、引言 在 C# 的应用开发中&#xff0c;配置文件就像是幕后的大管家&#xff0c;默默管理着应用程序的各种设置。今天&#xff0c;我们就来深入探索一下 C# 中极为重要的两个配置文件&#xff1a;app.config 和 web.config。无论是开发 Windows 应用程序&#xff0c;还是构建…

java 设计模式 工厂模式

什么是工厂模式 工厂模式&#xff08;Factory Pattern&#xff09;是一种创建型设计模式&#xff0c;它通过定义一个接口或抽象类来创建对象&#xff0c;但由子类决定具体实例化哪个类。简单来说&#xff0c;工厂模式将对象的实例化过程封装起来&#xff0c;客户端通过工厂方法…

[创业之路-248]:《华为流程变革:责权利梳理与流程体系建设》华为流程的前端拉动后端,与计算机软件的前端应用与后端程序的类比关系

华为的前端拉动后端模式与计算机前端应用与后端程序的类比关系&#xff0c;虽然两者属于不同的领域&#xff0c;但在某些方面存在有趣的相似性。以下是对这两者的类比关系的详细探讨&#xff1a; 一、华为的前端拉动后端模式 定义与特点&#xff1a; 华为的前端拉动后端模式是…

深入Node.js集群:原理、优势与搭建实战,如何应对高并发

文章目录 一、Node.js 集群简介二、Node.js 集群原理剖析2.1 主从模型2.2 负载均衡机制2.3 进程间通信&#xff08;IPC&#xff09; 三、Node.js 集群优势详解3.1 性能提升3.2 高可用性3.3 资源利用率优化 四、Node.js 集群搭建实战4.1 准备工作4.2 创建主控制节点4.3 工作节点…

数字普惠金融对新质生产力的影响研究(2015-2023年)

基于2015—2023年中国制造业上市公司数据&#xff0c;探讨了数字普惠金融对制造业企业新质生产力的影响及作用机理。研究发现&#xff0c;数字普惠金融有助于促进制造业企业新质生产力的发展&#xff0c;尤其是在数字普惠金融的使用深度较大的情况下&#xff0c;其对新质生产力…

数据仓库基础常见面试题

1.数据仓库是什么 ‌数据仓库&#xff08;Data Warehouse&#xff09;是一个面向主题的、集成的、非易失的、随时间变化的数据集合&#xff0c;用于支持企业的管理决策‌。它不同于传统的操作型数据库&#xff0c;后者主要用于处理日常业务交易和实时查询&#xff0c;而数据仓库…

记一次OpenEuler Linux磁盘分区表损坏的数据恢复

问题复现 原本有一台GIS地图服务器存放大量数据&#xff0c;突然有一天磁盘满了&#xff0c;于是运维人员照常进行磁盘扩容。但由于误操作&#xff0c;导致使用fdisk的时候把分区表损坏了&#xff0c;表现如下&#xff1a; 这里可以看到启动时能看到xvda被分为了xvda1和xvda2…