exit和vfork

在linux中,可以用以下函数结束正在运行的进程。

>> exit函数—库函数

#include <stdlib.h>

void exit(int value);

参数:value是返回给父进程的参数,低8位有效。

>> _exit函数—系统调用

#include<unistd.h>

void _exit(int value);

参数:value是返回给父进程的参数,低8位有效。

exec:启动一个程序,用这个程序将当前进程的内容替换掉

fork和vfork函数的区别:

>> vfork保证子进程先运行,在它调用exec或exit之后,父进程才可能被调度运行。

当子进程执行的时候,父进程是挂起的。

实例对比,先是fork的代码:

#include <sys/wait.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>

int main(){
    pid_t pid;
    pid = fork();
    if(pid < 0){
        perror("vfork error.\n");
    }else if(pid == 0){
        int i = 0;
        for(i = 0;i < 3;i++){
            printf("this is child process.\n");
            sleep(1);
        }
        _exit(1);
    }else{
        int i;
        for(i = 0;i < 5;i++){
            printf("this is father process.\n");
            sleep(1);
        }
    }
    return 0;
}
编译和执行结果如下:


将其中的fork函数替换为vfork之后如下:

#include <sys/wait.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>

int main(){
    pid_t pid;
    pid = vfork();
    if(pid < 0){
        perror("vfork error.\n");
    }else if(pid == 0){
        int i = 0;
        for(i = 0;i < 3;i++){
            printf("this is child process.\n");
            sleep(1);
        }
        _exit(1);
    }else{
        int i;
        for(i = 0;i < 5;i++){
            printf("this is father process.\n");
            sleep(1);
        }
    }
    return 0;
}
编译和执行结果如下:


>> vfork和fork一样都创建一个子进程,但它并不将父进程的地址空间完全复制到子进程中,因为子进程会立即调用exec(或exit),于是也就不访问该地址空间。相反,在子进程调用exec或exit之前,它在父进程的地址空间中运行,在exec之后子进程会有自己的进程空间。即共用父进程的资源

下面的例子可以看出,在子进程中改变全局变量的值,等子进程exit之后,父进程中同名变量的值已经被更改,因为两个指向的是同一个地址。

#include <sys/wait.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>

int num = 10;
int main(){
    unsigned int var = 2;
    pid_t pid;
    pid = vfork();
    if(pid < 0){
        perror("vfork error.\n");
    }else if(pid == 0){
        int i = 0;
        for(i = 0;i < 3;i++){
            num++;
            var++;
            printf("in child process: num = %d,var = %d.\n",num,var);
            sleep(1);
        }
        _exit(1);
    }else{
        printf("in father process: num = %d,var = %d.\n",num,var);
    }
    return 0;
}
编译和执行结果如下:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
fork和vfork是两个在操作系统中常见的系统调用函数,它们用于创建新的进程。它们之间的主要区别在于父进程和子进程之间的共享资源和执行顺序。 1. fork函数: - fork函数通过复制父进程的地址空间创建一个新的子进程。父进程和子进程之间共享文件描述符、内存映射等资源,但是每个进程有自己独立的副本。 - 子进程是父进程的副本,从fork函数调用的位置开始执行,父进程和子进程的执行顺序是不确定的,取决于操作系统的调度策略。 - 子进程会继承父进程的打开文件、信号处理器、当前工作目录等状态。 - fork函数返回两次,父进程中返回子进程的ID,子进程中返回0。 2. vfork函数: - vfork函数也是通过复制父进程的地址空间创建一个新的子进程,但是与fork不同,vfork直接共享父进程的地址空间。 - 子进程共享父进程的数据段、堆栈段等资源,但是不共享代码段。子进程在执行exec或者_exit后会替换父进程的地址空间。 - 子进程必须在调用exec或者_exit之前终止或者执行另一个程序,否则可能导致父进程和子进程之间的资源冲突。 - vfork函数返回子进程的ID,与fork函数不同的是,vfork函数不会返回两次。 总结: - fork函数创建子进程时,父进程和子进程之间共享资源但具有各自独立的副本。子进程可以在任何时间执行,父进程和子进程的执行顺序不确定。 - vfork函数创建子进程时,子进程共享父进程的地址空间,但是不共享代码段。子进程必须在exec或者_exit之前终止或者执行另一个程序。 - 在使用fork和vfork时,需要根据具体的需求和场景选择合适的函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值