在win32中如何调用cygwin.dll实现fork?
如下代码,fork返回-1,该怎么样才能正常调用cygwin.dll实现fork ?
#include "stdafx.h"
#include "MSCorEE.h"
#include "Winbase.h"//(include Windows.h)
#pragma comment(lib, "Kernel32.lib")// Kernel32.lib
int main()
{
HMODULE h = LoadLibrary("cygwin1.dll");
if (h) {
//printf("123");
void(*_cygwin_dll_init)() = (void(*)())GetProcAddress(h, "cygwin_dll_init");
_cygwin_dll_init();
int (*fork)() = (int(*)())GetProcAddress(h, "fork");
int pid = fork();
if (pid == -1) {
printf("fork failure %d", pid);
}
else if (pid == 0) {
return 11;
}
else {
printf("processid = %d", pid);
}
FreeLibrary(h);
}
system("pause");
return 0;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
直接在cygwin环境下用gcc编译,运行时带上cygwin1.dll即可。
Cygwin是有一套自己的C标准库和POSIX函数库的,不能直接拿来用,因为Cygwin模拟了一层UNIX转换层,这个层需要链接到它们的库,以及编译时生成额外代码,直接调用当然不行。
因为Windows本身没有提供fork的机制的API,也就是直接派生一个当前进程副本。
Windows思想写这种逻辑都是用线程的,因为CreateProcess是相当于fork+execvp,没法直接在子进程继续你的逻辑。Cygwin可以是因为它编译时产生了额外逻辑。