原来获取命令行是这样的:
int APIENTRY wWinMain(
_In_ HINSTANCE hInstance,
_In_opt_ HINSTANCE hPrevInstance,
_In_ LPWSTR lpCmdLine,
_In_ int nShowCmd
)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);
//...
return (int)msg.wParam;
}
上面的初始化代码里面有一个参数,lpCmdLine就是命令行。不过这样有一个问题——一个个去写字符串分析很烦,还弄得代码一大串。
前段时候,在网上看到了<stdlib.h>里面的__argc和__argv可以当成控制台里面的用。当时那个兴奋。火速完成了下面的代码。
int APIENTRY wWinMain(
_In_ HINSTANCE hInstance,
_In_opt_ HINSTANCE hPrevInstance,
_In_ LPWSTR lpCmdLine,
_In_ int nShowCmd
)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);
// 前初始化 - 参数配置等
#if _DEBUG_VER_
FILE *stream;
AllocConsole();
freopen_s(&stream, "CONOUT$", "w", stdout);
#endif
// 命令行
int cnum = __argc, i = 0;
char** cm = __argv;
while (cnum--)
{
printf("%s\r\n", cm[i]);
i++;
}
// 。。。
}
看出问题了吗?如果可能的话你可以自己去试试,运行就崩溃。本来这方面资料就少,翻遍百度找不到一个。后来,我发现__argv是char **型的,难道wWinMain里面不能出现ANSI的这种?
通过查找它们在<stdlib.h>中的定义,我找到了 __wargv ,是__argv对应的宽字符类型。思来想去都觉得是wWinMain里面不能出现ANSI的__argv这种问题,便马上改了改:
int APIENTRY wWinMain(
_In_ HINSTANCE hInstance,
_In_opt_ HINSTANCE hPrevInstance,
_In_ LPWSTR lpCmdLine,
_In_ int nShowCmd
)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);
// 前初始化 - 参数配置等
#if _DEBUG_VER_
FILE *stream;
AllocConsole();
freopen_s(&stream, "CONOUT$", "w", stdout);
#endif
// 命令行
int cnum = __argc, i = 0;
wchar_t** cm = __wargv;
while (cnum--)
{
wprintf(L"%s\r\n", cm[i]);
i++;
}
// ...
}
一测试,诶呀终于成功了。
因为网上没有这方面的说明,所以就把它记下来了,希望对遇到类似问题的有所帮助