linux学习之进程篇(一)

进程

1.PCB

  每个进程在内核中都有一个进程控制块(PCB)来维护进程相关的信息,Linux内的进程控制块是task_struct结构体。现在我们全面了解一下其中都有哪些信息。

  • 进程标示符(PID):描述本进程的唯一标示符,用来区别其他进程。父进程id(PPID)
  • 进程的状态,有运行、挂起、停止、僵尸等状态。
  • 进程切换时需要保存和恢复的一些CPU寄存器。
  • 描述虚拟地址空间的信息。
  • 描述控制终端的信息。
  • 当前工作目录
  • umask掩码
  • 文件描述符表,包含很多指向file结构体的指针
  • 和信号相关的信息
  • 用户id和组id
  • 控制终端、Session和进程组。
  • 进程可以使用的资源上限,用ulimit可以更改

2、虚拟地址

虚拟地址

在虚拟地址取内容时会映射到物理地址中取。0-3G是用户空间,3G-4G是内核空间。PCB是在kernel空间。只有操作系统的管理者才能看到所有的pcb。操作系统以页面为单位管理。每个页面可以设置R/W属性(常量区只有只读属性,所以写会出错)。通过系统调用能从用户态进入到内核态,通过软中断的手段。每个PCB里有一个指针指向文件描述符表。

3.进程的环境

  lib中定义的全局变量environ指向环境变量表,environ没有包含在任何头文件中,所以在使用时有用extern声明。

  由于父进程在调用fork创建子进程时会把自己的环境变量表也复制给子进程。按照惯例,环境变量字符串都是name=value这样的形式,大多数name由大写字母加下划线组成。

  获取和设置环境变量

 

 #include<stdlib.h>

 char *getenv(const char *name);

  

  getenv的返回值是指向value的指针,若未找到则为NULL

  

#include<stdlib.h>

int setenv(const char *name,const char *value,int rewrite);

void unsetenv(const char *name);

  putenv和setenv函数若成功则返回为0,若出错则返回非0。setenv将环境变量name的值设置为value。如果已存在环境变量name,那么若rewrite非0,在覆盖原来的定义;若rewrite为0,则不覆盖原来额定义,也不返回错误。unsetname删除name的定义,即使name没有定义也不返回错误。

4.进程的状态

进程的状态

  处理机现场保留在pcb的内核栈中,以便恢复执行。cpu的分时复用机制。

      修改进程资源限制,软限制可改,最大值不能超过硬限制,硬限制只有root用户可以更改。

    

#include<sys/time.h>
#include<sys/resource.h>
int getrlimit(int resource,struct rlimit *rlim);
int setrlimit(int resouce,const struct rlimit *rlim);

    查看进程资源限制

cat /proc/self/limits

ulimit -a
原文地址:https://www.cnblogs.com/rainbow1122/p/7811291.html