linux下创建新的进程
进程时每一个系统下必不可少的一个部分。每一个进程都有一个非负证整数的唯一进程ID。进程ID标识符总是唯一的。一般在linux创建一个进程是同fork()函数的。
函数fork()的原型
pid_t fork(void)
这个函数的主要主要特色是返回两次值,子进程返回0,父进程返回子进程ID。出错则返回-1。通过实例来了解一下这个函数。
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t pid;
int globalx = 2;
if ((pid = fork()) > 0){
int a = 1;
printf("parent is %d \n",a)
}
else if (pid == 0) {
int a = 1;
a++;
printf("child is %d \n",a);
}
else {
printf("error");
}
printf("all have: %d \n",globalx);
exit(0);
}
运行的结果如下
由这个例子的看的出来,他们唯一的区别只是在pid>0下的代码和pid==0下的的代码。fork()之后父函数和子函数实现不同的代码段,而且相互之间并不影响。
我们在再看下一个例子。
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t pid;
int globalx = 2;
if ((pid = fork()) > 0){
int a = 1;
for(int i=0;i<10;i++)
printf("parent is %d \n",a);
}
else if (pid == 0) {
int a = 1;
a++;
for(int i=0;i<10;i++)
printf("child is %d \n",a);
}
else {
printf("error");
}
printf("all have: %d \n",globalx);
exit(0);
}
运行的结果如下
当我们在那两个代码块加入循环时,就可以发现子进程和父进程,可以说时各自独立的,它们之间没有先后关系。如果子进场和父进程同时对一个文件进行操作,则需要考虑到这一点。
以上基本上是fork()函数两大特点。如果有错误和遗漏的地方,欢迎指出和补充。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。