使用fork函数创建一个进程
pid_t fork(void)
fork函数调用成功,返回两次
返回值为0;代表当前进程是子进程
返回值为非负数,代表当前进程为父进程
如果调用失败则返回-1
代码
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t pid;
pid=getpid();
fork();
printf("pid:%d,当前pid:%d\n",pid,getpid()); //getpid()是获取当前的pid用来判断目前有两个不同进程在执行这一行
sleep(1);//防止下图1的情况
return 0;
}
用了sleep(1);
现在说明有两个进程执行了fork()下面的代码。
优化上面的代码
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t pid;
pid=getpid();
fork();
if(pid == getpid()){//说明此时就是父进程,因为父进程就是一开始的进程
printf("这是父进程,pid:%d\n",getpid());
}else{
printf("这是子进程,pid:%d\n",getpid());
}
sleep(0.1);
return 0;
}
再清楚一点
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t pid;
pid_t pid2;
pid=getpid();
printf("在fork之前%d\n",pid);
fork();
pid2=getpid();
if(pid == pid2){//说明此时就是父进程,因为父进程就是一开始的进程
printf("这是父进程,pid:%d\n",getpid());
}else{
printf("这是子进程,pid:%d\n",getpid());
}
sleep(1);
return 0;
}
测试一下返回值
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t pid;
printf("父进程的pid :%d\n",getpid());
pid=fork();
if(pid > 0){//返回值为非负数,代表当前进程为父进程
printf("这是父进程,pid:%d\n",getpid());
}else if(pid == 0){//返回值为0;代表当前进程是子进程
printf("这是子进程,pid:%d\n",getpid());
}
sleep(1);
return 0;
}