下面的代码将一些文本设置为打开的记事本窗口。我的问题是它是如何安全工作的?
int _tmain(int argc, _TCHAR* argv[])
{
HWND hwnd = FindWindow(_T("Notepad"),_T("Untitled - Notepad"));
if(hwnd!=NULL)
{
wchar_t* pString = L"hi";
HWND hwndEdit = FindWindowEx(hwnd,NULL,_T("Edit"),NULL);
SendMessage(hwndEdit,WM_SETTEXT,0,(LPARAM)pString);
}
return 0;
}
指针"pString“存在于当前进程空间的虚拟内存中,它可能不是notepad.exe.But上下文中的有效内存地址。奇怪的是,它正确地设置了文本,这意味着该指针不仅在notepad.exe上下文中有效,而且还指向正确的字符串。这是怎么发生的?
这是否意味着我们可以有效地使用SendMessage作为进程间通信机制?
发布于 2013-04-02 18:07:05
对于某些消息,系统会自动将数据从一个进程编组到另一个进程-- WM_SETTEXT
是获得这种特殊处理的消息之一。
如果您真的想这样做,您当然可以将其用作双向数据传输(使用WM_SETTEXT
发送和使用WM_GETTEXT
接收)的IPC机制,但我怀疑它是否会如此高效。而且已经有一个专门为IPC - WM_COPYDATA
设计的消息。
发布于 2013-04-02 18:09:16
我们可以使用SendMessage
是!
有效的
不是
设置窗口的文本由操作系统处理。在这种情况下,Windows会自动封送数据。
https://stackoverflow.com/questions/15760608
复制相似问题