Keep,Note.1

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);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值