WM_COPYATA 与 PostMessage/SendMessage;const 的变量通过指针修改后?;指针与数组名

/*
2014-12-09 Leo.Zheng
今天想测试一下 WM_COPYATA 是否可以通过 PostMessage 来发送,于是搞了如下测试的代码。
测试结果:
(1) WM_COPYATA 通过 PostMessage 发送失败,无论是发送到本程序、还是发送到另一个进程。
(2) WM_COPYATA 通过 PostMessage 发送时,lpData/cbData 的赋值是需要注意的。否则,发送本程序时会有乱码出现。
说明:
另一个进程很简单:一个标准的对话框,然后对 WM_COPYATA 消息进行了映射,如下
ON_WM_COPYDATA()

BOOL CPC_MFC_RcvMsgDlg::OnCopyData(CWnd* pWnd, COPYDATASTRUCT* pCopyDataStruct)
{
	// TODO: Add your message handler code here and/or call default
	if(1 == pCopyDataStruct->dwData)
	{
		TRACE("receive copydata is: %s\r\n",(char *)pCopyDataStruct->lpData);
	}

	return CDialog::OnCopyData(pWnd, pCopyDataStruct);
}


*/

/*
运行一个窗体名为:“PC_MFC_RcvMsgDlg”的应用,用于测试接收 WM_COPYDATA 消息
*/
void CPC_MFCDlg::OnBnClickedButtonTestCopydata()
{
	// TODO: Add your control notification handler code here
	HWND hWnd = ::FindWindow(NULL,L"PC_MFC_RcvMsgDlg");
	char *pcTest = "测试WM_COPYATA通过PostMessage发送";


	COPYDATASTRUCT Cpds;
	Cpds.dwData = 1;
	Cpds.cbData = sizeof(char) * (strlen(pcTest) + 1);		// + 1 可以消除本程序接收到的字符串中的乱码
	Cpds.lpData = (LPVOID)pcTest;
#if 1
	SendMessage(WM_COPYDATA,NULL,(LPARAM)&Cpds);		// CPC_MFCDlg::OnCopyData 可以接收到消息,但 lpData 的值不对
	/*
	_CrtDbgReport: String too long or IO Error					// TRACE(L"CopyData: %s\r\n",(TCHAR *)pCopyDataStruct->lpData); 语句的输出
	send CopyData: 0x422040										// 可能是由于没有字符串结束符引起的
	或
	CopyData: 测试WM_COPYATA通过PostMessage发送垇喚斞wt烈w	// TRACE(L"CopyData: %s\r\n",(TCHAR *)pCopyDataStruct->lpData); 语句的输出
	send CopyData: 0x422040
	*/
	if(NULL != hWnd)
	{
		::SendMessage(hWnd,WM_COPYDATA,NULL,(LPARAM)&Cpds);		// 可以接收到消息,且字符串在不 +1 时也是正确的
	}
#else
	PostMessage(WM_COPYDATA,NULL,(LPARAM)&Cpds);		// CPC_MFCDlg::OnCopyData 接收不到消息
	if(NULL != hWnd)
	{
		::PostMessage(hWnd,WM_COPYDATA,NULL,(LPARAM)&Cpds);	// 接收消息的另一个程序也接收不到消息
	}
#endif
	TRACE(L"send CopyData: 0x%x\r\n",Cpds.lpData);
}


BOOL CPC_MFCDlg::OnCopyData(CWnd* pWnd, COPYDATASTRUCT* pCopyDataStruct)

{
	// TODO: Add your message handler code here and/or call default
	if(1 == pCopyDataStruct->dwData)
	{
		TRACE("CopyData: %s\r\n",(char *)pCopyDataStruct->lpData);	// 输出的字符串没有结束符,但在接收端接收到的数据是正确的(+ 1 可消除此问题)
	}


	return CDialog::OnCopyData(pWnd, pCopyDataStruct);
}

const 的变量通过指针修改后指针所指的值与原变量的值的关系?

{
	volatile const int i = 10;		// 不加 volatile 时 i 输出为 10; 说明 i 是从栈上读取的, 但内存中的数据已经发生了变化
	
	int *pi = const_cast<int *>(&i);
	++*pi;
	TRACE("i = %d;@i = 0x%x\r\n",i,&i);
	TRACE("pi = %d,@pi = 0x%x\r\n",*pi,pi);

	TRACE("\r\n");
	/*
	i = 10;@i = 0x12edb0
	pi = 11,@pi = 0x12edb0

	i = 11;@i = 0x12edb0
	pi = 11,@pi = 0x12edb0
	*/
}


指针的地址与内容:

TCHAR tcArray[100];
TCHAR *ptcPoint = tcArray;
TCHAR *ptcPoint2 = (TCHAR *)&tcArray;
TRACE("0x%X 0x%X 0x%X\r\n",tcArray,ptcPoint,ptcPoint2);
// 输入是相同的: 0x12EDBC 0x12EDBC 0x12EDBC

// TODO: 在此添加额外的初始化代码


{
	char *cHeadTest = new char[2048];
	if(NULL != cHeadTest)
	{
		ZeroMemory(cHeadTest,sizeof(char) * 2048);
		cHeadTest[0] = 'Z';		// 0x5A
		cHeadTest[1] = 'Y';		// 0x59
		TRACE("0x%x,0x%x,0x%x\r\n",cHeadTest,&cHeadTest,*cHeadTest);
		// 0x3b9358,0x12edb0,0x5a

		delete cHeadTest;
		cHeadTest = NULL;
	}
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

91program

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

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

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

打赏作者

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

抵扣说明:

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

余额充值