我在C中尝试了一个窗口示例,window.c,并在我的窗口上通过gcc将它编译成window.exe。当我在命令控制台上运行window.exe时,它可以工作,但命令控制台无法退出,所以我无法在同一个控制台中运行其他命令,为什么?当我在命令控制台上尝试使用exe扩展的putty.exe或其他窗口应用程序时,它的命令控制台将在程序运行或加载时退出。原因是否在window.c中没有包含main()?还有一个问题是为什么window.c中的代码可以在没有main()包含在程序中的自执行模式下运行? 请指教
#include <windows.h>
const char g_szClassName[] = "myWindowClass";
// Step 4: the Window Procedure
LRESULT CALLBACK WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
switch(msg)
{
case WM_CLOSE:
DestroyWindow(hwnd);
break;
case WM_DESTROY:
PostQuitMessage(0);
break;
default:
return DefWindowProc(hwnd, msg, wParam, lParam);
}
return 0;
}
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
LPSTR lpCmdLine, int nCmdShow)
{
WNDCLASSEX wc;
HWND hwnd;
MSG Msg;
//Step 1: Registering the Window Class
wc.cbSize = sizeof(WNDCLASSEX);
wc.style = 0;
wc.lpfnWndProc = WndProc;
wc.cbClsExtra = 0;
wc.cbWndExtra = 0;
wc.hInstance = hInstance;
wc.hIcon = LoadIcon(NULL, IDI_APPLICATION);
wc.hCursor = LoadCursor(NULL, IDC_ARROW);
wc.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);
wc.lpszMenuName = NULL;
wc.lpszClassName = g_szClassName;
wc.hIconSm = LoadIcon(NULL, IDI_APPLICATION);
if(!RegisterClassEx(&wc))
{
MessageBox(NULL, "Window Registration Failed!", "Error!",
MB_ICONEXCLAMATION | MB_OK);
return 0;
}
// Step 2: Creating the Window
hwnd = CreateWindowEx(
WS_EX_CLIENTEDGE,
g_szClassName,
"The title of my window",
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, CW_USEDEFAULT, 600, 300,
NULL, NULL, hInstance, NULL);
if(hwnd == NULL)
{
MessageBox(NULL, "Window Creation Failed!", "Error!",
MB_ICONEXCLAMATION | MB_OK);
return 0;
}
ShowWindow(hwnd, nCmdShow);
UpdateWindow(hwnd);
// Step 3: The Message Loop
while(GetMessage(&Msg, NULL, 0, 0) > 0)
{
TranslateMessage(&Msg);
DispatchMessage(&Msg);
}
return Msg.wParam;
}
答案 0 :(得分:1)
它可以工作,但命令控制台无法退出,所以我无法在同一个控制台中运行其他命令,为什么?当我在命令控制台上尝试使用exe扩展的putty.exe或其他窗口应用程序时,它的命令控制台将在程序运行或加载时退出。
从控制台启动的Windows应用程序应 不 阻止与控制台窗口的进一步交互。我对putty.exe一无所知,所以让我们以notepad.exe为例。它是一个标准的Windows应用程序,所以如果我从命令行运行它,Notepad会在一个新窗口中启动,然后我得到一个C:提示符。你完全正确地认为这是正常的。
正如您在此处所展示的那样,您的代码会正常运行。其他错误 - 可能是您的编译器或链接器设置。我建议你可能会瞄准控制台子系统,但接着应该抱怨你有错误的入口点。 (至少微软的工具链会;我对GCC不太确定。)这至少要检查一下。在构建时确保传递开关-mwindows
。
原因是否在window.c中没有包含main()?还有一个问题是为什么window.c中的代码可以在自执行模式下运行而不包含在程序中的main()?
不,这与它无关。代码中没有main()
函数的原因是因为WinMain()
函数充当了入口点。
从技术上讲,WinMain()
是用户定义的入口点。这是the conventional name and signature for the function in Windows applications。您可以将其视为与main()
类似,但实际上,main()
函数仍然存在,它只是隐藏在库代码中。构建Windows应用程序时链接的C运行时库定义实际入口点。它执行一些早期初始化任务,然后调用用户定义的入口点WinMain()
。
如果您在调试器下单步执行应用程序,则可以看到此操作,但如果将断点放在WinMain()
的顶部,则会错过它。虽然这就是你的代码首先开始执行的地方,正如我所解释的那样,在将控制权转交给WinMain()
之前,会先执行代码。因此,您需要开始踩踏EXE中的第一条指令。在Visual Studio中,您只需按 F11 即可进入步入。我不确定你使用的调试器是什么;您需要查看其文档。
或者你可以根本不用担心这一点,因为它实际上是你从未真正需要理解的esoterica。当您编写Windows应用程序时,只需将WinMain()
视为等同于main()
即可!