1.在用VC++6.0创建窗口时,我的步骤是这样的(跟着孙鑫教程里学的)。1,新建一个工程win32 application
确定,建一个空工程,确定。2,新建一个c++源文件,然后打代码。3,编译没问题,组建没问题,执行文件。达到效果后就退出(销毁)窗口,然后我改变代码中光标的value,换了...
确定,建一个空工程,确定。2,新建一个c++源文件,然后打代码。3,编译没问题,组建没问题,执行文件。达到效果后就退出(销毁)窗口,然后我改变代码中光标的value,换了另一种光标。接着编译没问题,组建出错了:
LINK : fatal error LNK1168: cannot open Debug/wenti.exe for writing
百度一下这个问题是因为wenti.exe这个 可执行文件没有关闭。打开进程的确是这个文件在运行,把这个文件关闭继续组建成功,执行顺利。
问题1:为什么我销毁了窗口(return 0,关闭了函数?)那个可执行文件还在运行?运行几次就会在管理器里看到几个相同的可执行文件运行?看孙鑫教程时管理器里运行的都是WinMain函数,我的程序运行时为什么任务管理器里没有这个函数?
2.关闭VC,从文件夹里打开C++源文件(用VC打开)编译成功,组建时出现问题:
LIBCD.lib(crt0.obj) : error LNK2001: unresolved external symbol _main
百度了这个问题是因为没有建立win32 Application工程,想想也是。打开的只是代码,
通过工程->设置->连接,改变工程选项成功组建,执行。
问题2:win32 Application(32位操作系统应用程序)这个东西到底是什么,其实我在创建这个窗口的时候只是照着视频做,其中过程是再干什么根本不知道。我理解的是组建的过程是将cpp源程序与win32 Application这个工程连接起来,这个工程到底是什么东西?MFC,DLL这些是函数库?
问题3:程序文件夹里生成的那些后缀不同文件都是什么东西?Debug(组建)文件夹里的文件是组建生成的文件吧?那个*.exe文件是执行生成的吗,都是些什么东西?
问体很长,先感谢回答我问题的大虾嘞。。 展开
LINK : fatal error LNK1168: cannot open Debug/wenti.exe for writing
百度一下这个问题是因为wenti.exe这个 可执行文件没有关闭。打开进程的确是这个文件在运行,把这个文件关闭继续组建成功,执行顺利。
问题1:为什么我销毁了窗口(return 0,关闭了函数?)那个可执行文件还在运行?运行几次就会在管理器里看到几个相同的可执行文件运行?看孙鑫教程时管理器里运行的都是WinMain函数,我的程序运行时为什么任务管理器里没有这个函数?
2.关闭VC,从文件夹里打开C++源文件(用VC打开)编译成功,组建时出现问题:
LIBCD.lib(crt0.obj) : error LNK2001: unresolved external symbol _main
百度了这个问题是因为没有建立win32 Application工程,想想也是。打开的只是代码,
通过工程->设置->连接,改变工程选项成功组建,执行。
问题2:win32 Application(32位操作系统应用程序)这个东西到底是什么,其实我在创建这个窗口的时候只是照着视频做,其中过程是再干什么根本不知道。我理解的是组建的过程是将cpp源程序与win32 Application这个工程连接起来,这个工程到底是什么东西?MFC,DLL这些是函数库?
问题3:程序文件夹里生成的那些后缀不同文件都是什么东西?Debug(组建)文件夹里的文件是组建生成的文件吧?那个*.exe文件是执行生成的吗,都是些什么东西?
问体很长,先感谢回答我问题的大虾嘞。。 展开
4个回答
展开全部
#include <windows.h>
#pragma comment(lib,"user32.lib")
#pragma comment(lib,"Gdi32.lib")
LRESULT CALLBACK WndProc(
HWND hwnd
,UINT message
,WPARAM wParam
,LPARAM lParam
);
HWND hWnd;//窗口句柄,定义为全局
int WINAPI WinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPSTR lpCmdLine,
int nCmdShow
)
{
MSG msg;
WNDCLASS wnd;
wnd.style = 0;
wnd.cbClsExtra = 0;//应该0
wnd.cbWndExtra = 0;//均为0
wnd.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);//背景填充颜色
wnd.hCursor = LoadCursor(NULL,IDC_ARROW);//光标,使用默认光标参数一为NULL
wnd.hIcon = LoadIcon(NULL,IDI_EXCLAMATION);//图标
wnd.hInstance = hInstance;//句柄
wnd.lpfnWndProc = WndProc;//消息处理
wnd.lpszClassName = "XP";//类名
wnd.lpszMenuName = NULL;//菜单名
RegisterClass(&wnd);//注册
hWnd = CreateWindow("XP","窗口",WS_OVERLAPPEDWINDOW,100,100,500,500,NULL,NULL,hInstance,NULL);//创建窗口,参考MSDN
ShowWindow(hWnd,SW_SHOWNORMAL);//显示
UpdateWindow(hWnd);//更新窗口
while(GetMessage(&msg,NULL,0,0))
{//消息循环
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return 0;
}
/*LRESULT CALLBACK WindowProc(HWND hwhd,uMsg,WPARAM wParam,LPARAM IParam)
消息响应函数定义
hwnd:指向窗口的句柄。
uMsg:指定消息类型。
wParam:消息
IParam:消息*/
LRESULT CALLBACK WndProc(
HWND hwnd
,UINT message
,WPARAM wParam
,LPARAM lParam
)
{
switch(message)
{
case WM_CLOSE://关闭
if(MessageBox(hWnd,"是否退出","询问",MB_YESNO)==IDYES)//使用全局消息框
PostQuitMessage(0);//将WM_QUIT加入消息队列中
break;
case WM_KEYDOWN://键盘按下,一种消息类型,MFC会更全
switch(wParam)
{
case VK_UP:
MessageBox(hWnd,"上","按下",MB_OK);
case VK_RBUTTON:
MessageBox(hWnd,"鼠标右键","按下",MB_OK);
break;
case VK_MENU:
MessageBox(hWnd,"Alt","按下",MB_OK);
break;
case VK_END:
MessageBox(hWnd,"END","按下",MB_OK);
break;
case VK_LEFT:
MessageBox(hWnd,"左","按下",MB_OK);
break;
case VK_RIGHT:
MessageBox(hWnd,"右","按下",MB_OK);
break;
case VK_DOWN:
MessageBox(hWnd,"下","按下",MB_OK);
break;
case VK_CONTROL:
MessageBox(hWnd,"Ctrl","按下",MB_OK);
break;
case VK_ESCAPE:
MessageBox(hWnd,"Esc","按下",MB_OK);
// PostQuitMessage(0);
break;
case VK_SHIFT:
MessageBox(hWnd,"SHIFT","按下",MB_OK);
break;
default: break;
}
default:
return DefWindowProc(hwnd,message,wParam,lParam);//缺省处理
}
return(0);
}
没有外部定义.......
MFC是标准的win32 Application文件
DLL为动态链接库Library,
连接文件
可以使用类进行封装窗口创建
MFC也是如此
可以加入afxwin.h头文件 对mfc库的调用
C++的半面向对象的思想mfc对基本数据也有所封装,
若果没有C基础,对其不熟悉,可能会进展不顺
对于一些函数传参不了,可以参考MSDN
#pragma comment(lib,"user32.lib")
#pragma comment(lib,"Gdi32.lib")
LRESULT CALLBACK WndProc(
HWND hwnd
,UINT message
,WPARAM wParam
,LPARAM lParam
);
HWND hWnd;//窗口句柄,定义为全局
int WINAPI WinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPSTR lpCmdLine,
int nCmdShow
)
{
MSG msg;
WNDCLASS wnd;
wnd.style = 0;
wnd.cbClsExtra = 0;//应该0
wnd.cbWndExtra = 0;//均为0
wnd.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);//背景填充颜色
wnd.hCursor = LoadCursor(NULL,IDC_ARROW);//光标,使用默认光标参数一为NULL
wnd.hIcon = LoadIcon(NULL,IDI_EXCLAMATION);//图标
wnd.hInstance = hInstance;//句柄
wnd.lpfnWndProc = WndProc;//消息处理
wnd.lpszClassName = "XP";//类名
wnd.lpszMenuName = NULL;//菜单名
RegisterClass(&wnd);//注册
hWnd = CreateWindow("XP","窗口",WS_OVERLAPPEDWINDOW,100,100,500,500,NULL,NULL,hInstance,NULL);//创建窗口,参考MSDN
ShowWindow(hWnd,SW_SHOWNORMAL);//显示
UpdateWindow(hWnd);//更新窗口
while(GetMessage(&msg,NULL,0,0))
{//消息循环
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return 0;
}
/*LRESULT CALLBACK WindowProc(HWND hwhd,uMsg,WPARAM wParam,LPARAM IParam)
消息响应函数定义
hwnd:指向窗口的句柄。
uMsg:指定消息类型。
wParam:消息
IParam:消息*/
LRESULT CALLBACK WndProc(
HWND hwnd
,UINT message
,WPARAM wParam
,LPARAM lParam
)
{
switch(message)
{
case WM_CLOSE://关闭
if(MessageBox(hWnd,"是否退出","询问",MB_YESNO)==IDYES)//使用全局消息框
PostQuitMessage(0);//将WM_QUIT加入消息队列中
break;
case WM_KEYDOWN://键盘按下,一种消息类型,MFC会更全
switch(wParam)
{
case VK_UP:
MessageBox(hWnd,"上","按下",MB_OK);
case VK_RBUTTON:
MessageBox(hWnd,"鼠标右键","按下",MB_OK);
break;
case VK_MENU:
MessageBox(hWnd,"Alt","按下",MB_OK);
break;
case VK_END:
MessageBox(hWnd,"END","按下",MB_OK);
break;
case VK_LEFT:
MessageBox(hWnd,"左","按下",MB_OK);
break;
case VK_RIGHT:
MessageBox(hWnd,"右","按下",MB_OK);
break;
case VK_DOWN:
MessageBox(hWnd,"下","按下",MB_OK);
break;
case VK_CONTROL:
MessageBox(hWnd,"Ctrl","按下",MB_OK);
break;
case VK_ESCAPE:
MessageBox(hWnd,"Esc","按下",MB_OK);
// PostQuitMessage(0);
break;
case VK_SHIFT:
MessageBox(hWnd,"SHIFT","按下",MB_OK);
break;
default: break;
}
default:
return DefWindowProc(hwnd,message,wParam,lParam);//缺省处理
}
return(0);
}
没有外部定义.......
MFC是标准的win32 Application文件
DLL为动态链接库Library,
连接文件
可以使用类进行封装窗口创建
MFC也是如此
可以加入afxwin.h头文件 对mfc库的调用
C++的半面向对象的思想mfc对基本数据也有所封装,
若果没有C基础,对其不熟悉,可能会进展不顺
对于一些函数传参不了,可以参考MSDN
追问
我的GetMessage()参数写错了。错误的代码GetMessage(&msg,hwnd,0,0),改成GetMessage(&msg,NULL,0,0),错误解决!之前代码:
前面是一般的WinMain函数
while(GetMessage(&msg,hwnd,0,0))
{TranslateMessage(&msg);
DispatchMessage(&msg);}
return 0;//退出WainMain()函数,就是推出.exe执行进程?
是因为GetMessage(&msg,hwnd,0,0)错误的参数导致循环成死循环,return 0;不能执行?关闭之后没关闭的进程占CPU近50%
展开全部
问题2,源代码是需要工作空间支持的。Win32 Application即(Win32 API)。所谓的这个工程,是把许多源代码组合在一起而已。编译时,将所有文件编译成相对应的*.o,组建的时候,将它们连接起来,再与系统库(如MFC)连接,组合成可执行文件
问题三
*.opt应该说是临时控件,对工程的修改都保存在这里,除非你保存文件。
plg是编译连接时产生的“日志”
obj就是编译成的目标文件
pdb、pch是编译时需要的文件
问题三
*.opt应该说是临时控件,对工程的修改都保存在这里,除非你保存文件。
plg是编译连接时产生的“日志”
obj就是编译成的目标文件
pdb、pch是编译时需要的文件
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
第一个问题主要是:关闭窗口跟结束应用程序是有区别的
建议在看孙鑫的视频的时候结合一些书来看看,以前也是这样过来的。坚持,慢慢就会好地。
建议在看孙鑫的视频的时候结合一些书来看看,以前也是这样过来的。坚持,慢慢就会好地。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一起来学习。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询