在运行时决定一个应用程序属于控制台/windows子系统

Decide an application to be of console/windows subsystem at run time

本文关键字:属于 应用程序 控制台 子系统 windows 一个 决定 运行时      更新时间:2023-10-16

我有一个MFC应用程序,它生成一些报告并在GUI中显示相同的内容。我需要在传递某些命令行参数时将其作为控制台应用程序运行。在控制台模式下,它将在标准输出/错误中生成报告/错误,我应该能够将其重定向到任何文件。

为例。 C:/temp MyApp.exe --console > report.txt 应该在控制台模式下运行我的exe并将所有输出重定向到文本文件。但是如果我在没有任何控制台参数的情况下运行它,它应该像一个默认的MFC应用程序。

为了达到我的要求,到目前为止我所做的是,将Linker > System > SubsytemWindows改为Console,并添加WinMainCRTStartup atLinker > Advanced > Entry Point

所以现在我的应用程序工作正常,当我运行它与--console参数从控制台/批处理文件。但是当我直接运行它时,它仍然打开一个cmd窗口(当然,因为它现在是一个控制台应用程序)。然而,我使用FreeConsole()方法来摆脱它,但它仍然闪烁了一秒钟。

所以我很好奇是否有一种方法可以完全摆脱它,要么通过在运行时决定应用程序的子系统,要么通过任何其他技巧?

我建议将您的GUI应用程序与windows子系统保持一致。

一开始,当解析命令行,而不是创建GUI窗口(MFC初始化),您可以创建一个控制台或附加AttachConsole()

作为概念证明,下面是它的样子(例如在CxxxApp::InitInstance()中):

...  // init code but before the the CMainFrame is created 
if(...) {   // suppose you want to go to the console
    if (! AttachConsole(ATTACH_PARENT_PROCESS))   // try to hijack existing console of command line
        AllocConsole();                           // or create your own.
    DWORD nw,nr;    // demo with windows native console i/o 
    char buff[32]; 
    WriteConsole(GetStdHandle(STD_OUTPUT_HANDLE), L"Who are you ? ", 14, &nw, NULL); 
    ReadConsoleA(GetStdHandle(STD_INPUT_HANDLE), buff, sizeof(buff), &nr, NULL);
    WriteConsoleA(GetStdHandle(STD_OUTPUT_HANDLE), "Hello ", 6, &nw, NULL);
    WriteConsoleA(GetStdHandle(STD_OUTPUT_HANDLE), buff, nr, &nw, NULL);
    ReadConsoleA(GetStdHandle(STD_INPUT_HANDLE), buff, 1, &nr, NULL);
    ...
}

如果您想使用c++ cin/cout,则需要额外的工作。另一个SO问题针对的是重定向计数。