linux进程

使用pstree以数结构的方式查看linux现有进程

liunx在启动的时候会由内核创建一个init进程

其他进程都是init进程执行fork函数创建的,init进程的pid是1

fork函数是干嘛的?

fork函数简单来说就是克隆进程,克隆出来的进程称为子进程,原来的叫父进程
fork函数执行的时候先复制父进程的PCB(PCB在内核空间),然后再复制用户空间的代码段、数据段、栈、堆、程序计数器
至于,克隆出来的进程为什么干不一样的活,下面会说明。

当我们在编写C程序的时候想获取该进程的pid怎么做?

  • 引入头文件unistd.h,该文件在/usr/include/unistd.h
  • 直接调用getpid,成功返回该进程的pid,失败返回-1

进程的生命周期

C程序的启动函数是main函数,当启动main函数前会调用特殊函数获取main函数的入口地址,然后给main函数传递参数

进程的中止




进程内存空间分布


正文就是代码:通常是共享只读的
初始化数据:程序执行前明确赋值的,比如int a=10;
未初始化数据:没有明确赋值的,使用的默认值,如int a[10];

环境变量表

每个进程都有自己的环境变量表

c程序获取环境变量


还有其他类似的函数,比如设置等

c程序创建进程

父子进程异同

fork的用法

原文地址:https://www.cnblogs.com/treasury/p/12758959.html