僵尸进程
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
int main(int argc, const char *argv[])
{
//僵尸进程,子进程运行完成之后父进程不收回子进程的资源
pid_t cpid=fork();
if(cpid>0)
{
while(1)
{
printf("this is parent\n");
sleep(1);
}
}
else if(0==cpid)
{
}
else
{
perror("fork");
return -1;
}
return 0;
}
2.孤儿进程
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
int main(int argc, const char *argv[])
{
//孤儿进程,关闭父进程,子进程还在运行中,成为孤儿进程
pid_t cpid=fork();
if(0==cpid)
{
while(1)
{
printf("this is child %d %d\n",getppid(),getpid());
sleep(1);
}
}
else if(cpid>0)
{
//exit(0);
}
else
{
perror("fork");
return -1;
}
return 0;
}
3.守护进程(幽灵进程)
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
int main(int argc, const char *argv[])
{
//创建孤儿进程,所以文物都运行在孤儿进程中,形式上脱离终端控制
if(fork()==0)
{
//创建新的会话组
setsid();
//修改孤儿进程的运行目录为不可卸载的文件系统
chdir("/");
//重设文件权限掩码:守护进程一般保留文件原有权限
umask(0);
//关闭所有从父进程继承过来的文件描述符;需要使用的时候重新open
for(int i=0;i<getdtablesize();i++)
{
close(1);
}
while(1)
{
//守护进程的功能代码
sleep(1);
}
}
return 0;
}