(done) 关于 GNU/Linux API setenv 的实验

写一个下面的代码来验证

c 复制代码
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>

int main() {
    // 设置环境变量 MY_VAR 的值为 "hello_world"
    if (setenv("MY_VAR", "hello_world", 1) != 0) {
        perror("setenv");
        return 1;
    }

    pid_t pid;

    // 使用 fork() 创建一个新进程
    pid = fork();

    if (pid < 0) {
        // 错误处理:fork() 返回负值表示创建子进程失败
        fprintf(stderr, "Fork failed\n");
        return 1;
    } else if (pid == 0) {
        // 在子进程中执行的代码
        printf("Child process: Hello, I am the child process! PID: %d\n", getpid());
        // 获取并打印设置的环境变量 MY_VAR 的值
        char *value = getenv("MY_VAR");
        if (value != NULL) {
            printf("in child, MY_VAR is set to: %s\n", value);
        } else {
            printf("MY_VAR is not set.\n");
        }

        pid_t pid;
        // 使用 fork() 创建一个新进程
        pid = fork();
        if (pid == 0) {
                char *value = getenv("MY_VAR");
                if (value != NULL) {
                    printf("in grandchild, MY_VAR is set to: %s\n", value);
                } else {
                    printf("MY_VAR is not set.\n");
                }
        }

    } else {
        // 在父进程中执行的代码
        printf("Parent process: Hello, I am the parent process! PID: %d\n", getpid());
        printf("Parent process: Child's PID: %d\n", pid);
    }

    // 父子进程都会执行的代码
    printf("Hello from process PID: %d\n", getpid());

    return 0;
}

编译并执行后,执行结果如下:

复制代码
Parent process: Hello, I am the parent process! PID: 923571
Parent process: Child's PID: 923572
Hello from process PID: 923571
Child process: Hello, I am the child process! PID: 923572
in child, MY_VAR is set to: hello_world
Hello from process PID: 923572
in grandchild, MY_VAR is set to: hello_world
Hello from process PID: 923573

可以看到环境变量 MY_VAR 被传递给了儿子和孙子

此时我们在 terminal echo $MY_VAR 试试

可以看到 MY_VAR 为空。也就是说,setenv 所设置的变量的 Lifecycle 仅限于程序还活着的时候

相关推荐
镜中人★19 小时前
408操作系统考纲知识点
linux·运维·服务器
liulilittle19 小时前
rinetd 端口转发工具技术原理
linux·服务器·网络·c++·端口·通信·转发
fy zs19 小时前
应用层自定义协议和序列化
linux·网络·c++
末日汐19 小时前
库的制作与原理
linux·后端·restful
tmacfrank19 小时前
Binder 预备知识
linux·运维·binder
cnstartech19 小时前
esxi-vmware 虚拟机互相打开
linux·运维·服务器
mcdx19 小时前
bootm的镜像加载地址与uImage镜像的加载地址、入口地址之间的关系
linux
不知疲倦的仄仄19 小时前
第四天:Netty 核心原理深度解析&EventLoop、Future/Promise 与 Pipeline
linux·服务器·网络
橘颂TA19 小时前
【Linux 网络编程】网络是怎么 “跑” 起来的?从协议入门到 TCP/ IP 模型的底层逻辑
linux·运维·服务器·网络
我的golang之路果然有问题19 小时前
python中 unicorn 热重启问题和 debug 的 json
java·服务器·前端·python·json