C++;可执行文件打开命令窗口 我有一个非常简单的C++类,它只打开一个空白的Windows窗口,但是我注意到每次我双击.exe,它打开窗口,但是它也打开命令提示符窗口。 有没有一种简单快捷的方法来阻止这个命令提示符窗口的出现
提前欢呼, KSC++;可执行文件打开命令窗口 我有一个非常简单的C++类,它只打开一个空白的Windows窗口,但是我注意到每次我双击.exe,它打开窗口,但是它也打开命令提示符窗口。 有没有一种简单快捷的方法来阻止这个命令提示符窗口的出现,c++,executable,C++,Executable,提前欢呼, KS #包括 const char g_szClassName[]=“myWindowClass”; //步骤4:窗口过程 LRESULT回调WndProc(HWND HWND,UINT msg,WPARAM WPARAM,LPARAM LPARAM) { 开关(msg) { 案例WM_LBUTTONDOWN: { char szFileName[MAX_PATH]; HINSTANCE HINSTANCE=GetModuleHandle(NULL); GetModuleFileNa
#包括
const char g_szClassName[]=“myWindowClass”;
//步骤4:窗口过程
LRESULT回调WndProc(HWND HWND,UINT msg,WPARAM WPARAM,LPARAM LPARAM)
{
开关(msg)
{
案例WM_LBUTTONDOWN:
{
char szFileName[MAX_PATH];
HINSTANCE HINSTANCE=GetModuleHandle(NULL);
GetModuleFileName(hInstance,szFileName,最大路径);
MessageBox(hwnd,szFileName,“此程序为:”,MB|U OK | MB|U图标信息);
}
打破
案例WM_结束:
窗口(hwnd);
打破
案例WM_销毁:
PostQuitMessage(0);
打破
违约:
返回DefWindowProc(hwnd、msg、wParam、lParam);
}
返回0;
}
int WINAPI WinMain(HINSTANCE HINSTANCE、HINSTANCE HPPreInstance、,
LPSTR lpCmdLine,int nCmdShow)
{
WNDCLASSEX wc;
HWND-HWND;
味精;
//步骤1:注册窗口类
wc.cbSize=sizeof(WNDCLASSEX);
wc.style=1;
wc.lpfnWndProc=WndProc;
wc.cbClsExtra=0;
wc.cbWndExtra=0;
wc.hInstance=hInstance;
wc.hIcon=LoadIcon(空,IDI_应用程序);
wc.hCursor=LoadCursor(空,IDC_箭头);
wc.hbrBackground=(HBRUSH)(彩色窗口+1);
wc.lpszMenuName=NULL;
wc.lpszClassName=g_szClassName;
wc.hIconSm=LoadIcon(空,IDI_应用程序);
如果(!RegisterClassEx(&wc))
{
MessageBox(NULL,“窗口注册失败!”,“错误!”,
MB|U图标连接| MB|U OK);
返回0;
}
//步骤2:创建窗口
hwnd=CreateWindowEx(
前客户,
g_szClassName,
“WinApp-2”,
WS_重叠窗口,
CW_USEDEFAULT,CW_USEDEFAULT,240,120,
NULL,NULL,hInstance,NULL);
if(hwnd==NULL)
{
MessageBox(NULL,“窗口创建失败!”,“错误!”,
MB|U图标连接| MB|U OK);
返回0;
}
显示窗口(hwnd、nCmdShow);
更新窗口(hwnd);
//步骤3:消息循环
while(GetMessage(&Msg,NULL,0,0)>0)
{
翻译信息(&Msg);
发送消息(&Msg);
}
返回Msg.wParam;
}
只需链接到/SUBSYSTEM:WINDOWS
选项,而不是/SUBSYSTEM:CONSOLE
如果当前允许编译器调用链接器,您可能希望将
/c
传递到cl.exe
以仅进行编译,然后对生成的对象文件调用link.exe/SUBSYSTEM:WINDOWS
。只需使用/SUBSYSTEM:WINDOWS
选项链接,而不是/SUBSYSTEM:CONSOLE
如果您当前允许编译器调用链接器,您可能希望将<代码> /C<代码>传递到<代码> C.exe < /C>中编译,然后调用<代码> LINK.exe/Sudis:Windows < /C> >生成的目标文件(s)。< /P>您没有C++类。C++是一种多范式语言,不是所有的事物都是对象或类。而且你的代码没有任何类。你没有C++类。C++是一种多范式语言,不是所有的事物都是对象或类。而且您的特定代码中没有任何类。
#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_LBUTTONDOWN:
{
char szFileName[MAX_PATH];
HINSTANCE hInstance = GetModuleHandle(NULL);
GetModuleFileName(hInstance, szFileName, MAX_PATH);
MessageBox(hwnd, szFileName, "This program is:", MB_OK | MB_ICONINFORMATION);
}
break;
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 = 1;
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,
"WinApp-2",
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, CW_USEDEFAULT, 240, 120,
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;
}