僵尸进程
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/wait.h>
int main(int argc, const char *argv[])
{
pid_t cpid = fork();
if(cpid > 0)
{
int a;
pid_t wpid = waitpid(-1,&a,0);
printf("wpid=%d\n",wpid);
while(1)
{
printf("lw66666667\n");
sleep(1);
}
}
else if(cpid == 0)
{
printf("nice try __%d__\n",__LINE__);
exit(0);
}
else
{
perror("fork");
return -1;
}
return 0;
}
孤儿进程
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/types.h>
int main(int argc, const char *argv[])
{
pid_t cpid=fork();
if(cpid > 0)
{
printf("father process is exit %d %d\n",getpid(),cpid);
exit(0);
}
else if(0 == cpid)
{
while(1)
{
printf("this is son process\n %d %d %d\n",getppid(),getpid(),cpid);
sleep(1);
}
}
else
{
perror("fork");
return -1;
}
return 0;
}
守护进程
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
#include<sys/stat.h>
#include<sys/types.h>
int main(int argc, const char *argv[])
{
//直接创建孤儿进程
if(0 == fork())
{
//创建新的会话组
setsid();
//修改孤儿进程的运行目录为不可卸载的文件系统
chdir("/");
//重新设置文件权限掩码;守护进程一般保留文件原有权限
umask(0);
//关闭所有从父亲继承过来的文件描述符,需要使用的时候重新open
for(int i=0;i<getdtablesize();i++)
{
close(i);
}
//功能代码
while(1)
{
char s[20]="you are the best!!!";
int fd = open("/safe.txt",O_WRONLY | O_CREAT | O_TRUNC,0664);
write(fd,s,sizeof(s));
sleep(1);
}
}
return 0;
}