使用CreateProcess,可以';t获取CREATE_NO__窗口以抑制控制台

使用CreateProcess,可以';t获取CREATE_NO__窗口以抑制控制台,c,windows,C,Windows,我想在不弹出控制台窗口的情况下启动一个过程(为了简单起见,我们将使用记事本) 我确信我错过了一些非常简单的东西,下面是我最简化的测试用例: #include <windows.h> #include <stdio.h> #include <tchar.h> void _tmain( int argc, TCHAR *argv[] ) { STARTUPINFO si; PROCESS_INFORMATION pi; ZeroMemo

我想在不弹出控制台窗口的情况下启动一个过程(为了简单起见,我们将使用记事本)

我确信我错过了一些非常简单的东西,下面是我最简化的测试用例:

#include <windows.h>
#include <stdio.h>
#include <tchar.h>

void _tmain( int argc, TCHAR *argv[] )
{
    STARTUPINFO si;
    PROCESS_INFORMATION pi;

    ZeroMemory( &si, sizeof(si) );
    si.cb = sizeof(si);
    ZeroMemory( &pi, sizeof(pi) );

    // Start the child process. 
    if( !CreateProcess( NULL,   // No module name (use command line)
        "notepad",        // Command line
        NULL,           // Process handle not inheritable
        NULL,           // Thread handle not inheritable
        FALSE,          // Set handle inheritance to FALSE
        CREATE_NO_WINDOW,              // No creation flags
        NULL,           // Use parent's environment block
        NULL,           // Use parent's starting directory 
        &si,            // Pointer to STARTUPINFO structure
        &pi )           // Pointer to PROCESS_INFORMATION structure
    ) 
    {
        printf( "CreateProcess failed (%d).\n", GetLastError() );
        return;
    }

    // Wait until child process exits.
    WaitForSingleObject( pi.hProcess, INFINITE );

    // Close process and thread handles. 
    CloseHandle( pi.hProcess );
    CloseHandle( pi.hThread );
}
#包括
#包括
#包括
void _tmain(int argc,TCHAR*argv[])
{
STARTUPINFO si;
处理信息;
零内存(&si,sizeof(si));
si.cb=sizeof(si);
零内存(&pi,sizeof(pi));
//启动子进程。
如果(!CreateProcess(NULL,//没有模块名称(使用命令行)
“记事本”,//命令行
NULL,//进程句柄不可继承
NULL,//线程句柄不可继承
FALSE,//将句柄继承设置为FALSE
创建\u无\u窗口,//无创建标志
NULL,//使用父级的环境块
NULL,//使用父级的起始目录
&si,//指向STARTUPINFO结构的指针
&pi)//指向进程信息结构的指针
) 
{
printf(“CreateProcess失败(%d)。\n”,GetLastError());
返回;
}
//等待子进程退出。
WaitForSingleObject(pi.hProcess,无限);
//关闭进程和线程句柄。
CloseHandle(pi.hProcess);
CloseHandle(pi.hThread);
}

您正在从父进程(控制台应用程序)创建一个新进程(notepad.exe),并让父进程等待子进程完成。控制台窗口是父进程的主窗口。您可以隐藏和恢复,如下所示

// Notice how hiding the console window causes it to disappear from
// the Windows task bar. If you only want to make it minimize, use
// SW_MINIMIZE instead of SW_HIDE.
void _tmain(int argc, TCHAR *argv[])
{
    ShowWindow( GetConsoleWindow(), SW_HIDE );

    // create a new process and wait for it to finish

    ShowWindow( GetConsoleWindow(), SW_RESTORE );
}

将应用程序子系统从控制台更改为Windows。在VS2008中,这在链接器属性“系统”下。 然后将主要功能更改为:

int APIENTRY _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow)

并更改代码以返回int。

这就是如何使用MinGW将应用程序子系统从控制台更改为Windows,添加以下链接器标志:

-Wl,-subsystem,windows 

记事本没有控制台窗口。如果您试图阻止应用程序的主窗口出现,请尝试使用STARTUPINFO结构中的wShowWindow元素。如果我编译了它,一个cmd窗口将与记事本一起弹出(虽然我实际上试图在没有控制台的情况下调用批处理文件,但记事本似乎是一个更简单的例子,可以实现同样的功能)。我想您会发现这是应用程序本身的命令窗口。要确认,请在CreateProcess之前放置一个printf命令,并查看输出是否转到您关心的窗口。是的,我相信您是正确的。基本上,我只是想创建一个可执行文件,在后台运行一个批处理文件而不弹出窗口。基本上和这些bat-to-exe转换器一样,但我不想为几行代码花费40美元。虽然我是一个java程序员,而不是c,但这几行代码让我感到很痛苦。我需要什么标题?无法识别GetConsoleWindow。抱歉,我是一名Java EE程序员,不是C,不是windows,也不是GUI,只是想快速完成这项小任务。您需要包含文件windows.h;)我只是使用MinGW从文本文件进行编译(除了这20行代码之外,我不尝试接受任何东西,我也不是C或GUI程序员)。