代码:
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
int main(void)
{
pid_t pid;
int count=0;
pid=vfork();
count++;
printf("count=%d\n",count);
return 0; //exit(0);
}
运行结果
count=1
count=1
总线错误
分析:
vfork()会产生一个新的子进程.但是vfork创建的子进程与父进程共享数据段,而且由vfork创建的 。
子进程将先于父进程运行.fork()的使用详见百度词条fork().
vfork()用法与fork()相似.但是也有区别,具体区别归结为以下3点:
1. fork():子进程拷贝父进程的数据段,代码段. vfork():子进程与父进程共享数据段.
2. fork():父子进程的执行次序不确定. vfork():保证子进程先运行,在调用exec或exit之前与父进程数据是共享的,在它调用exec ,或exit之后父进程才可能被调度运行
3. vfork()保证子进程先运行,在她调用exec或exit之后父进程才可能被调度运行。如果在调用这两个函数之前子进程依赖于父进程的进一步动作,则会导致死锁。
返回值
如果vfork()成功则在父进程会返回新建立的子进程代码(PID),
而在新建立的子进程中则返回0。如果vfork失败则直接返回-1,失败原因存于errno中。
解决方法:
仔细看上述的区别3
父进程执行了一个无效的内存引用信号为 SIGSEGV 默认动作是异常终止 将 return 0 改为 exit(0) 就行了 |
父进程 执行了一个无效的内存引用
信号为 SIGSEGV 默认动作是异常终止 将 return 0 改为 exit(0) 就行了 |