如何在Window 7的后台运行C窗口程序

时间:2016-06-19 11:28:30

标签: c window

我在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;
}

1 个答案:

答案 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()即可!