021 多语言协同执行(了解)

fork + exec 系列函数创建子进程并执行其他程序(跨语言衔接示例)

CSDN 相关文章 fork(2) - Linux 手册页 exec(3) - Linux 手册页

在 Linux 系统编程中,fork()exec() 是进程控制的两大核心。本文将演示如何使用 fork 创建子进程,再使用 exec 执行外部程序,展示多语言之间的 协同执行 过程。


1. fork + exec 基础原理

  • fork():复制当前进程,返回两次(一次给父进程,一次给子进程)
  • exec*():用新程序 替换当前进程映像(进程 ID 不变)

通常模式:

c 复制代码
pid_t pid = fork();
if (pid == 0)                               // 子进程执行新程序
{
    execl("/bin/ls", "ls", "-l", NULL);
    perror("execl");                        // 出错处理
}
else                                        // 父进程继续执行
{
    wait(NULL);                             // 等待子进程退出
}

2. 执行 Python 脚本的示例

1. Python 文件:script.py

python 复制代码
# script.py
print("Hello from Python script!")

2. C 程序执行 Python 脚本:

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

int main()
{
    pid_t pid = fork();
    if (pid == 0)                       // 子进程执行 python 脚本
    {
        execl("/usr/bin/python3", "python3", "script.py", NULL);
        perror("exec failed");
    }
    else                                // 父进程等待
    {
        wait(NULL);
        printf("Python 脚本执行完毕\n");
    }
    return 0;
}

编译并运行:

bash 复制代码
gcc run_python.c -o run_python
./run_python

运行结果示例:

csharp 复制代码
Hello from Python script!
Python 脚本执行完毕

3. 执行 C++ 程序的示例

1. C++ 程序:hello.cpp

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
    cout << "Hello, world!" << endl;
    return 0;
}

编译:

bash 复制代码
g++ hello.cpp -o hello_cpp

2. C 程序调用该可执行文件:

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

int main()
{
    pid_t pid = fork();
    if (pid == 0)
    {
        execl("./hello_cpp", "hello_cpp", NULL); // 执行 C++ 程序
        perror("exec failed");
    }
    else
    {
        wait(NULL);
        printf("C++ 程序执行完毕\n");
    }
    return 0;
}

编译并运行:

bash 复制代码
gcc run_cpp.c -o run_cpp
./run_cpp

运行结果示例:

复制代码
Hello, world!
C++ 程序执行完毕

4. 常见问题

问题 说明
exec 不执行? 路径错误、参数没加 NULL、权限不够
子进程未退出? 忘记 wait() 等待

5. 总结

fork + exec 提供了 Linux 编程中最灵活的跨语言进程调用方式。你可以:

  • 用 C 控制调度
  • 执行 Python、C++、Shell 等不同程序
  • 实现自定义脚本执行平台、服务型任务处理器等

此处仅演示最简单的 多语言协同执行,带环境变量、传参数等其他形式不涉及。

相关推荐
lzh2004091914 小时前
深入学习Linux进程间通信:解析消息队列
linux·c++
苏宸啊14 小时前
进程替换库函数
linux
时光之源15 小时前
安装WSL2后在其中安装Ubuntu24.04.4再安装OpenClaw全流程傻瓜式教学:WSL2 + Ubuntu 24.04 + OpenClaw
linux·运维·ubuntu·openclaw·龙虾
大袁同学15 小时前
【进程信号】:溯源硬件起中断,掌舵内核控信号
linux·信号处理
能喵烧香15 小时前
跨越系统的开源尝试:KDE Windows版本全解析
linux·windows·开源
智算菩萨15 小时前
OpenAI Codex 国内使用完全指南:Windows/macOS/Linux 三平台详细安装配置教程(现在最新的有gpt-5.3-codex和gpt-5.4)
linux·windows·gpt·macos·ai·ai编程·codex
Yupureki15 小时前
《Linux网络编程》4.应用层HTTP协议
linux·服务器·c语言·网络·c++·http
孙同学_15 小时前
【Linux篇】网络层与数据链路层详解
linux·网络·智能路由器
拾光Ծ15 小时前
【Linux系统】进程信号(上)
linux·运维·服务器·面试·信号处理
咖喱o15 小时前
网络-堆叠
linux·运维·服务器·网络