我假设您在 Windows 下运行。两个不同的进程在完全独立的地址空间中运行。如果您正在考虑将指向 MyFunc(在进程 1 中)的指针传递给另一个进程,这实际上可以完成,但这非常困难并且有更简单的方法(您必须将函数本身放在对两个过程)。
显然,您不需要返回值,因为您说它们是异步运行的。因此,您只需要知道如何启动另一个进程(您已经知道这一点-- CreateProcess)以及如何告诉它要运行什么。如果第二个进程是执行 MyFunc 然后退出的可执行文件,则只需使用 CreateProcess 启动它,在 lpCommandLine 中传递任何参数并让它在完成时完成。
如果您需要其他进程运行某个任意函数(直到运行时才知道),您可以将一组可用函数放入一个 DLL 中,并将 DLL 的名称和函数的名称传递给第二个进程(在 lpCommandLine )。然后,第二个进程使用 LoadLibrary 加载 DLL,并使用 GetProcAddress 获取函数的地址(按名称)。
如果您需要其他进程来运行某个函数并且它不支持上述命令行参数,那么您可以使用一种称为代码注入的技术。这是一种非常先进的技术,可让您在另一个进程中运行任意代码。如果这是您需要的,我会将如何做到这一点附加到这个答案中。如果是这样,请发表评论。
在阅读您需要在其他进程中调用固定函数的评论后,我添加了以下内容。将参数字符串放入命令行的第二个参数中(第一个参数是可执行文件名——不要忘记包含它!):
void MyFunc (TCHAR* argument) {
// Validate argument then do something with it...
}
int _tmain(int argc, _TCHAR* argv[])
{
if (argc > 1) {
MyFunc(argv[1]);
}
return 0;
}
以下是调用该过程的方法(注意:我认为这是正确的,但我并没有实际编译和测试此代码段。它只是为了给你一个大致的想法):
STARTUPINFO si;
PROCESS_INFORMATION pi;
memset (&si, 0, sizeof(si));
memset (&pi, 0, sizeof(pi));
GetStartupInfo(&si);
si.cb = sizeof(si);
si.dwFlags = STARTF_USESHOWWINDOW;
TCHAR CommandLine[1024];
// MyFuncArgument (type == TCHAR*, declaration not shown) is the single argument for MyFunc
// (put it in quotes if needed):
_stprintf(CommandLine, _T("DoMyFunc.exe %s"), MyFuncArgument);
if (CreateProcess (_T(".\\DoMyFunc.exe"), CommandLine, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi) != 0) {
_tprintf (_T("CreateProcess Succeeded\n"));
}
else {
_tprintf (_T("CreateProcess Failed\n"));
}