vs2010写MFC第一个程序的坎坷经历-已解决

WINDOWS的消息机制

问题1:安装MSDN后vs2010闪退:

Visual Studio遇到了异常。这可能是由某个扩展导致的。您可以在命令行上使用/og参数运行应用程序,然后检查文件C:\Users\AdministratorAppData\Roaming\Microsoft\VisualStudio\10.0\ActivityLog.xml以获取详细信息。

MSDN 2008把某个DLL的注册路径给修改掉了,所以VS2010加载插件的时候出错。
网上的解决方案是进入注册表修改某个CLSID对应的InProcServer32数据,但是我却没找到这个CLSID。
不过还好文件肯定是C:\Program Files (x86)\Common Files\microsoft shared\MSEnv\textmgrp.dll

直接打开CMD,Vista以上版本的系统需要右键以管理员权限执行,然后输入
regsvr32 “C:\Program Files (x86)\Common Files\microsoft shared\MSEnv\textmgrp.dll” 即可

在这里插入图片描述

问题2:VS2010 C++程序编译错误 ‘C:\Windows\SysWOW64\ntdll.dll’, Cannot find or open the PDB file

执行问题一的方法解决,我用了这个博客里的方法没有反而电脑极其卡:失败方法

问题3:vs2010编译 时 char* 类型形参与LPWSTR 类型的实参不兼容 的解决办法

参考博客:解决方法

问题4:error C2275: “XXXX”: 将此类型用作表达式非法

参考博客:解决方法

vs2010写第一个MFC程序成功:

#include <windows.h> //底层实现窗口 的头文件

//6处理窗口过程

//CALLBACK  代表__stdcall 参数的传递顺序:从右到左 以此入栈,并且在函数返回前 清空堆栈
LRESULT CALLBACK WindowProc(
	HWND hwnd, //消息所属的窗口句柄
	UINT uMsg, //具体消息名称  WM_XXXX 消息名
	WPARAM wParam, //键盘附加消息
	LPARAM lParam  //鼠标附加消息
	)
{
	switch (uMsg)
	{
	case WM_CLOSE:
		//所有xxxWindow为结尾的方法 ,都不会进入到消息队列中,而是直接执行
		DestroyWindow(hwnd); //DestroyWindow 发送另一个消息 WM_DESTROY
		break;
	case  WM_DESTROY:
		PostQuitMessage(0);
		break;
	case WM_LBUTTONDOWN: //鼠标左键按下
			{
			int xPos = LOWORD(lParam);
			int yPos = HIWORD(lParam);

			char buf[1024];
			wsprintf(buf,TEXT("x = %d,y = %d"), xPos, yPos);

			MessageBox(hwnd, buf, TEXT("鼠标左键按下"), MB_OK);

			break;
			}
	case WM_KEYDOWN: //键盘
		MessageBox(hwnd, TEXT("键盘按下"), TEXT("键盘按下"), MB_OK);
		break;

	case WM_PAINT: //绘图
		{
			PAINTSTRUCT ps; //绘图结构体
			HDC hdc = BeginPaint(hwnd, &ps);

			TextOut(hdc, 100, 100, TEXT("HELLO"), strlen("HELLO"));

			EndPaint(hwnd, &ps);
		}

		break;
	}

	


	//返回值用默认处理方式
	return DefWindowProc(hwnd, uMsg, wParam, lParam);
}

//程序入口函数

//WINAPI 代表__stdcall 参数的传递顺序:从右到左 以此入栈,并且在函数返回前 清空堆栈
int WINAPI WinMain(
	HINSTANCE hInstance,  //应用程序实例句柄 
	HINSTANCE hPrevInstance, //上一个应用程序句柄,在win32环境下,参数一般为NULL,不起作用了
	LPSTR lpCmdLine, //char * argv[] 
	int nShowCmd) //显示命令 最大化、最小化 正常
{
	HWND hwnd;
	MSG msg;
	//1、设计窗口
	//2、注册窗口
	//3、创建窗口
	//4、显示和更新
	//5、通过循环取消息
	//6、处理消息 (窗口过程)

	//1、设计窗口
	WNDCLASS wc;
	wc.cbClsExtra = 0; //类的额外的内存 
	wc.cbWndExtra = 0; //窗口额外的内存
	wc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH); //设置背景
	wc.hCursor = LoadCursor(NULL, IDC_HAND); //设置光标 如果第一个参数为NULL,代表使用系统提供的光标
	wc.hIcon = LoadIcon(NULL, IDI_ERROR); //图标   如果第一个参数为NULL,代表使用系统提供的光标
	wc.hInstance = hInstance;  //应用程序实例句柄  传入WinMain中的形参即可
	wc.lpfnWndProc = WindowProc;  //回调函数  窗口过程
	wc.lpszClassName = TEXT("WIN"); //指定窗口类名称
	wc.lpszMenuName = NULL; //菜单名称
	wc.style = 0; //显示风格 0代表默认风格

	//2、注册窗口类
	RegisterClass(&wc);

	//3、创建窗口
	/*
	lpClassName,  类名 
	lpWindowName, 标题名
	dwStyle,  WS_OVERLAPPEDWINDOW 风格
	x,  显示坐标    CW_USEDEFAULT  默认值
	y,
	nWidth, 宽高
	nHeight, 
	hWndParent,  父窗口 NULL
	hMenu,  菜单 NULL
	hInstance,  实例句柄 hInstance
	lpParam) 附加值 NULL 
	*/

	 hwnd = CreateWindow(wc.lpszClassName, TEXT("WINDOWS"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, hInstance, NULL);

	//4、 显示和更新
	ShowWindow(hwnd, SW_SHOWNORMAL);
	UpdateWindow(hwnd);

	//5、 通过循环取消息
	/*
	 HWND        hwnd; 主窗口句柄
	 UINT        message; 具体消息名称
	 WPARAM      wParam; 附加消息 键盘消息
	 LPARAM      lParam; 附加消息 鼠标消息
	 DWORD       time;  消息产生时间
	 POINT       pt;    附加消息  鼠标消息  x y
	*/
	

	while (GetMessage(&msg, NULL, 0, 0))
	{
		/*
		  _Out_ LPMSG lpMsg, 消息
		  _In_opt_ HWND hWnd, 捕获窗口 填NULL代表捕获所有的窗口
		  _In_ UINT wMsgFilterMin,  //最小和最大的过滤的消息  一般填入0
		  _In_ UINT wMsgFilterMax)  //填0代表捕获所有消息
		*/
		//if (GetMessage(&msg, NULL, 0, 0) == FALSE)
		//{
		//	break;
		//}

		//翻译消息
		TranslateMessage(&msg);

		//不为false
		//分发消息
		DispatchMessage(&msg);

	}

	
	


	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

磁生电

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值