1、获取环境变量:
char* getenv(const char* name) 成功就返回环境变量的值,失败返回NULL (include <stdlib.h>)
include <stdio.h>
#include <stdlib.h>
int main()
{
printf("homepath is [%s]\n",geienv("home"));
return 0;
}
2、进程
创建一个新的进程 pid_t fork(void); 返回值:失败-1 成功就两次返回(父进程返回子进程id)(子进程返回0)
获得当前进程id pid_t getpid(void)
获得当前进程父进程id pid_t getppid(void)
fork之后会新出来一个子进程,子进程从fork之后开始
3、查看进程信息
ps --------ps aux ps ajx可以追述进程之间的血缘关系
kill --------给进程发送一个信号 kill - 9 pid杀si进程
4、创建n个子进程(要掌握)
int main()
{
int n=5;
int i=0;
pid_t pid=0;
for(i=0;i<5;i++)
{
pid=fork();
if(pid==0)
{
//son
printf("i am child,pid=%d,pidd=%d\n",getpid(),getppid());
break;//子进程退出循环的接口
}
else if(pid>0)
{
//father
printf("i am father,pid=%d,pidd=%d\n",getpid(),getppid());
}
}
while(1)
{
sleep(1);
}
return 0;
}
5
5、父子进程遵循 读时共享写时复制 的原则
这两个进程的变量都是独立的,存在不同的地址中,不是共用的,这点要注意。
6、exec族函数
执行其他程序 int execl(const char* path,const char* arg,…
执行程序时,使用PATH环境变量,执行的程序可以不用加路径 int execlp(const char* file,const char* arg,…
file是要执行的程序,arg参数列表(最后需要一个NULL作为结尾哨兵),返回值只有当其失败才返回
7、孤儿进程 僵尸进程
孤儿(orphan):父进程dead,子进程被init进程领养(ppid=1)
僵尸(zombie):子进程dead,父进程没有回收子进程的 资源(PCB上的)
如何回收僵尸进程:不能kill命令清除,因为kill只是用来终止进程,而僵尸进程已经终止,正确方法是kill父进程,子进程由init领养,负责回收
孤儿进程可以通过命令 kill -9 pid 杀si
8、子进程回收---->回收子进程,知道子进程死亡原因
作用:①阻塞等待子进程死亡 ②回收子进程资源 ③查看死亡原因
pid_t wait(int* status);
status传出参数,返回值,成功返回终止的子进程ID,失败返回-1
子进程死亡原因:正常死亡WIFEXITED,若WIFEXITED为真,使用WEXITSTATUS得到退出状态
非正常死亡WIFSIGALED,若WIFSIGNALED为真,使用WTERMSIG的到信号pid_t wait(pid_t pid,int* status,int options);