僵尸进程
#include <stdio.h>
#include <string.h>
#include <stdlib.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("僵尸出来了!!!!\n");
sleep(1);
}
}
else if(0 == cpid)
{
}
else
{
perror("fork");
return -1;
}
return 0;
}
孤儿进程
#include <stdio.h>
#include <string.h>
#include <stdlib.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("我是一个孤儿!!!!\n");
sleep(1);
}
}
else if(0 < cpid)
{
}
else
{
perror("fork");
return -1;
}
return 0;
}
守护进程(幽灵进程)
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>
int main(int argc, const char *argv[])
{
//创建孤儿进程,所有进程都运行在孤
//儿进程中,形式上脱离终端控制
pid_t cpid = fork();
printf("%d\n",cpid);
if(0 == cpid)
{
//创建新的会话组
setsid();
//修改孤儿进程的运行目录为不可卸载的文件系统
chdir("/");
//重设文件权限掩码:守护进程一般保留文件原有权限
umask(0);
//关闭所有从父进程继承过来的文件描述符,
//需要使用时重新open
for(int i = 0; i < getdtablesize(); i++)
{
close(i);
}
//守护进程的功能代码
while(1)
{
char s[10] = "1234";
int fd = open("/txt.txt",O_RDWR | O_APPEND | O_CREAT,0664);
write(fd,s,sizeof(s));
sleep(3);
}
}
return 0;
}