我假设你在 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"));
}