链接并拨打两个独立的电源

时间:2015-05-04 16:06:16

标签: c gcc linker ld

是否可以通过一些链接器魔术将两个文件与两个单独的main()链接在一起,然后添加第三个控制main(),它将在运行时决定调用其他两个主电源中的哪一个?

想象一下:

/* test1.c */
include <stdio.h>

int main()
{
    printf("Test1\n");
}

/* test2.c */
include <stdio.h>

int main()
{
    printf("Test2\n");
}

/* controller.c */
int main()
{
    int x;
    // x gets set somehow
    if (x == 1)
        // call main from test1.c
    else if (x == 2)
        // call main from test2.c
}

我意识到这可能是一个奇怪的问题,但我正在尝试解决Cray超级计算机上的约束,它允许我每个节点只运行一个可执行文件。我明确地不想修改test1.ctest2.c

2 个答案:

答案 0 :(得分:2)

您可以尝试使用PIE和动态链接:

/* controller.c */

#include <stdio.h>
#include <errno.h>
#include <dlfcn.h>

int main(int argc, char *argv[])
{
    int retval, (*pmain)(int argc, char *argv[]);
    void *prg = dlopen(argv[1], RTLD_LAZY);

    pmain = dlsym(prg, "main");
    retval = (*pmain)(argc - 1, &argv[1]);
    dlclose(prg);
    return retval;
}

编译并运行,它适用于我的Linux:

gcc controller.c -o controller -ldl
gcc -fPIE -pie -Wl,--export-dynamic test1.c -o test1
gcc -fPIE -pie -Wl,--export-dynamic test2.c -o test2
./controller ./test1
Test1
./controller ./test2
Test2

答案 1 :(得分:0)

简而言之,没有办法。不管怎么说都不是。

可能的解决方案是使用例如system(或forkexec您自己)在新流程中从外部运行特定程序。

另一个解决方案是将不同main函数的功能放在单独的函数中,如果定义了特定的预处理器宏,则main有条件编译,main函数只需调用执行实际工作的特殊功能。