进程间通讯 —— 共享内存
来源:互联网 发布:bodymovin插件 mac 编辑:程序博客网 时间:2024/06/08 18:35
进程间通讯 —— 共享内存
通过内存共享的方式来进行进程之间的通讯,可以通过发送端进程在接收端进程中开辟一段内存空间,然后往该内存空间内写入数据,并通知接收端读取数据来达到。
实现代码片段
发送端:
BOOL SendProcessMessage(){HWND hWnd;hWnd = FindWindow(NULL, "Recv"); // 查找接收端窗口if (!hWnd){MessageBox(g_hWnd, "找不到通信进程", "error", MB_OK | MB_ICONERROR);return FALSE;}DWORD dwProcessId;GetWindowThreadProcessId(hWnd, &dwProcessId); // 获取句柄窗口所在进程IDHANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwProcessId); // 获取进程句柄if (!hProcess){MessageBox(g_hWnd, "打开进程失败", "error", MB_OK | MB_ICONERROR);return FALSE;}LPVOID lpAddress = VirtualAllocEx(hProcess, NULL, 1024, MEM_COMMIT, PAGE_EXECUTE_READWRITE); // 在目标进程中申请一块内存if (!lpAddress){MessageBox(g_hWnd, "在进程中分配内存失败", "error", MB_OK | MB_ICONERROR);return FALSE;}char buf[] = "hello world!";if (!WriteProcessMemory(hProcess, lpAddress, buf, sizeof(buf), NULL)) // 向内存中写入数据{MessageBox(g_hWnd, "在进程分配内存中写入数据失败", "error", MB_OK | MB_ICONERROR);return FALSE;}SendMessage(hWnd, WM_READMEMORY, NULL, (LPARAM)lpAddress); // 给目标窗口发送接收到数据的消息以及存放数据的内存地址Sleep(100); // 放弃CPU时间片的分配,其它线程才能读取到消息VirtualFreeEx(hProcess, lpAddress, 0, MEM_RELEASE); // 释放虚拟内存return TRUE;}
接收端:
case WM_READMEMORY:char buf[1024];ReadProcessMemory(GetCurrentProcess(), (LPVOID)lParam, buf, sizeof(buf), NULL); // 在内存中读取数据MessageBox(g_hWnd, buf, "", MB_OK);break;
- 进程间通讯 —— 共享内存
- 进程间通讯——共享内存
- 进程间通讯——共享内存
- 进程间通讯——共享内存
- 进程间通讯—共享内存
- 缓冲区设计—进程间通讯(POSIX 共享内存)
- 进程间通讯-共享内存
- 进程间通讯----共享内存
- 进程间通讯---共享内存
- 进程间通讯-共享内存
- 进程间通讯:共享内存
- 进程间通讯概述管道通讯信号通讯共享内存
- Linux笔记_进程通讯——共享内存
- 进程间通讯-共享内存2(代码)
- 进程间通讯共享内存的具体步骤
- 使用内存共享机制进程间通讯
- 共享内存实现进程间通讯
- 共享内存实现进程间通讯 收藏
- 总结从hello word到Spring Aop框架_提炼精髓
- STM32菜鸟成长记录---RS485通讯协议的应用
- 数据(type)_语法(逻辑)_技术(对象)
- COM线程模型-套间
- 解决KMPlayer不能播放部分高清rmvb格式文件的问题
- 进程间通讯 —— 共享内存
- IO流技术_总结
- STM32开发板-环境篇
- CoUninitialize进程内COM对象创建规则
- 网络编程_总结
- java基础之一网打尽_总结的威力
- QT中的随机函数的用法
- 死锁_why
- 基于微博的股票市场预测(初步构想)