測(cè)試一下WM_COPYATA 是否可以通過(guò) PostMessage 來(lái)發(fā)送
/*
2014-12-09 Leo.Zheng
今天想測(cè)試一下 WM_COPYATA 是否可以通過(guò) PostMessage 來(lái)發(fā)送,于是搞了如下測(cè)試的代碼。
測(cè)試結(jié)果:
(1) WM_COPYATA 通過(guò) PostMessage 發(fā)送失敗,無(wú)論是發(fā)送到本程序、還是發(fā)送到另一個(gè)進(jìn)程。
(2) WM_COPYATA 通過(guò) PostMessage 發(fā)送時(shí),lpData/cbData 的賦值是需要注意的。否則,發(fā)送本程序時(shí)會(huì)有亂碼出現(xiàn)。
說(shuō)明:
另一個(gè)進(jìn)程很簡(jiǎn)單:一個(gè)標(biāo)準(zhǔn)的對(duì)話框,然后對(duì) WM_COPYATA 消息進(jìn)行了映射,如下
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:?%srn",(char?*)pCopyDataStruct->lpData); } return?CDialog::OnCopyData(pWnd,?pCopyDataStruct); }
*/
/*
運(yùn)行一個(gè)窗體名為:“PC_MFC_RcvMsgDlg”的應(yīng)用,用于測(cè)試接收 WM_COPYDATA 消息
*/
void?CPC_MFCDlg::OnBnClickedButtonTestCopydata() { //?TODO:?Add?your?control?notification?handler?code?here HWND?hWnd?=?::FindWindow(NULL,L"PC_MFC_RcvMsgDlg"); char?*pcTest?=?"測(cè)試WM_COPYATA通過(guò)PostMessage發(fā)送"; 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?的值不對(duì) /* _CrtDbgReport:?String?too?long?or?IO?Error //?TRACE(L"CopyData:?%srn",(TCHAR?*)pCopyDataStruct->lpData);?語(yǔ)句的輸出 send?CopyData:?0x422040 //?可能是由于沒(méi)有字符串結(jié)束符引起的 或 CopyData:?測(cè)試WM_COPYATA通過(guò)PostMessage發(fā)送垇喚斞wt烈w //?TRACE(L"CopyData:?%srn",(TCHAR?*)pCopyDataStruct->lpData);?語(yǔ)句的輸出 send?CopyData:?0x422040 */ if(NULL?!=?hWnd) { ::SendMessage(hWnd,WM_COPYDATA,NULL,(LPARAM)&Cpds); //?可以接收到消息,且字符串在不?+1?時(shí)也是正確的 } #else PostMessage(WM_COPYDATA,NULL,(LPARAM)&Cpds); //?CPC_MFCDlg::OnCopyData?接收不到消息 if(NULL?!=?hWnd) { ::PostMessage(hWnd,WM_COPYDATA,NULL,(LPARAM)&Cpds); //?接收消息的另一個(gè)程序也接收不到消息 } #endif TRACE(L"send?CopyData:?0x%xrn",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:?%srn",(char?*)pCopyDataStruct->lpData); //?輸出的字符串沒(méi)有結(jié)束符,但在接收端接收到的數(shù)據(jù)是正確的(+?1?可消除此問(wèn)題) } return?CDialog::OnCopyData(pWnd,?pCopyDataStruct); }
const 的變量通過(guò)指針修改后指針?biāo)傅闹蹬c原變量的值的關(guān)系?
{ volatile?const?int?i?=?10; //?不加?volatile?時(shí)?i?輸出為?10;?說(shuō)明?i?是從棧上讀取的,?但內(nèi)存中的數(shù)據(jù)已經(jīng)發(fā)生了變化 int?*pi?=?const_cast(&i); ++*pi; TRACE("i?=?%d;@i?=?0x%xrn",i,&i); TRACE("pi?=?%d,@pi?=?0x%xrn",*pi,pi); TRACE("rn"); /* i?=?10;@i?=?0x12edb0 pi?=?11,@pi?=?0x12edb0 i?=?11;@i?=?0x12edb0 pi?=?11,@pi?=?0x12edb0 */ }
指針的地址與內(nèi)容:
TCHAR?tcArray[100]; TCHAR?*ptcPoint?=?tcArray; TCHAR?*ptcPoint2?=?(TCHAR?*)&tcArray; TRACE("0x%X?0x%X?0x%Xrn",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%xrn",cHeadTest,&cHeadTest,*cHeadTest); //?0x3b9358,0x12edb0,0x5a delete?cHeadTest; cHeadTest?=?NULL; } }