分类: C/C++
2008-03-14 15:32:22
不过,这样的方法都不错!
我在开始的时候,使用了字符地址作为消息参数进行传递,可是由于进程间都是独立的4GB内存空间,当接到我的字符消息的时候,就程序就误以为是自已的进程空间的地址,所以就把读取了这个地址,一般结果来看,不是乱码就是空字符串。
那么我们有什么方法可以在消息中进行字符串的传递呢?我们可以使用两个Windows的消息分别进行一个字符串的两个进程间的传递,
一个消息是WM_SETTEXT。
一个消息是WM_COPYDATA。
以下我来分析这两个消息怎么实现,
最简单的是使用WM_SETTEXT的消息了,这个方法只是使用一个字符串的地址作为一个消息参数就可以实现了两个不同进程间的消息的互发了。
原因是因为这个消息会为这个字符串分配一个内存空间,在接收方就可以根据这个地址把这个字符串读取保存了
CString str = _T( "Hello" ); HWND hWndReceived = FindWindow( "Receiver", NULL ); SendMessage( hWndReceived, WM_SETTEXT, 0, (LPARAM) str );
在接收方这样处理消息:
加入消息映射宏:
BEGIN_MESSAGE_MAP(CMyWnd, CWnd) //{{AFX_MSG_MAP(CMyWnd) ... ON_MESSAGE( WM_SETTEXT, OnSetTextMsg ) ... //}}AFX_MSG_MAP END_MESSAGE_MAP() ...
加入消息映射函数:
afx_msg void OnSetTextMsg( WPARAM wParam, LPARAM lParam) OnSetTextMsg( WPARAM wParam, LPARAM lParam ) { char str[ 256 ]; wsprintf( str, "%s", (char*) lParam ); // 加入处理这个字符串的语句 ..... }BEGIN_MESSAGE_MAP(CMyWnd, CWnd) //{{AFX_MSG_MAP(CMyWnd) ... ON_WM_COPYDATA() ... //}}AFX_MSG_MAP END_MESSAGE_MAP() ...使用WM_COPYDATA:
CString str = _T( "Hello" ); HWND hWndReceived = FindWindow( "Receiver", NULL ); COPYDATASTRUCT cpd; cpd。dwData = 0; cpd。cbData = strDataToSend。GetLength(); cpd。lpData = (void*)str。GetBuffer(cpd。cbData); SendMessage( hWndReceived, WM_COPYDATA, 0, (LPARAM) & cpd ); str。ReleaseBuffer();加入映射宏:
映射函数:
BOOL CMyWnd::OnCopyData(CWnd* pWnd, COPYDATASTRUCT* pCopyDataStruct) { CString strRecievedText = (LPCSTR) (pCopyDataStruct->lpData); return CMyWnd::OnCopyData(pWnd, pCopyDataStruct); }
这样就可以实现了不同进程间两个字符串之间的互发!
结束语:
这只是一些简单的方法,对这些感兴趣的或需要源代码的朋友,可以跟我联系。