进程间通讯SendMessage

2024-03-04 17:58
文章标签 进程 通讯 sendmessage

本文主要是介绍进程间通讯SendMessage,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PostMessage貌似只能用于进程内通讯,不同进程间通讯可以用SendMessage和共享内存等方式。这里理出SendMessage的用法,方便日后查阅。

发送消息的进程代码:

const UINT messageID = RegisterWindowMessage("SingletonApplication");char szTemp[1024] = { 0 };
sprintf(szTemp, "LayeredWindow_%d", iWndID);//窗口名
HWND hTemp = ::FindWindow(NULL, szTemp);//窗口句柄
BYTE* pGlobal = (BYTE*)::GlobalAlloc(GMEM_FIXED, str.length());//全局内存
if (!pGlobal)
{return;
}
else
{ZeroMemory(pGlobal, str.length());memcpy(pGlobal, str.c_str(), str.length());
}
COPYDATASTRUCT copyData = {0};
copyData.dwData = messageID;
copyData.cbData = (DWORD)(str.length()+1);
copyData.lpData = pGlobal;
SendMessage(hTemp, WM_COPYDATA, 0, (LPARAM)&copyData);
::GlobalFree((HGLOBAL)pGlobal);//释放全局内存

这里注意要分配全局内存,否则另一进程接受消息时,消息被释放,接受的是乱码,无法解析。

接受消息的进程(这里是win32窗口。如果是MFC窗口进程,可采用消息映射,在响应函数内解析接受的消息,示例代码网上例子较多,这里不再赘述)代码:

在WndProc消息响应函数添加消息响应:

const UINT messageID = RegisterWindowMessage(L"SingletonApplication");
.
.
.
case WM_COPYDATA:{//两进程间通讯COPYDATASTRUCT* copy_data_structure = { 0 };copy_data_structure = (COPYDATASTRUCT *)lParam;if (copy_data_structure->dwData == messageID){string str = (char*)copy_data_structure->lpData;//接受的消息}}break;
.
.
.

 

这篇关于进程间通讯SendMessage的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/773980

相关文章

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

java 进程 返回值

实现 Callable 接口 与 Runnable 相比,Callable 可以有返回值,返回值通过 FutureTask 进行封装。 public class MyCallable implements Callable<Integer> {public Integer call() {return 123;}} public static void main(String[] args

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(

Golang进程权限调度包runtime

关于 runtime 包几个方法: Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行GOMAXPROCS:设置最大的可同时使用的 CPU 核数Goexit:退出当前 goroutine(但是defer语句会照常执行)NumGoroutine:返回正在执行和排队的任务总数GOOS:目标操作系统NumCPU:返回当前系统的 CPU 核数量 p

如何保证android程序进程不到万不得已的情况下,不会被结束

最近,做一个调用系统自带相机的那么一个功能,遇到的坑,在此记录一下。 设备:红米note4 问题起因 因为自定义的相机,很难满足客户的所有需要,比如:自拍杆的支持,优化方面等等。这些方面自定义的相机都不比系统自带的好,因为有些系统都是商家定制的,难免会出现一个奇葩的问题。比如:你在这款手机上运行,无任何问题,然而你换一款手机后,问题就出现了。 比如:小米的红米系列,你启用系统自带拍照功能后

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

C++编程:ZeroMQ进程间(订阅-发布)通信配置优化

文章目录 0. 概述1. 发布者同步发送(pub)与订阅者异步接收(sub)示例代码可能的副作用: 2. 适度增加缓存和队列示例代码副作用: 3. 动态的IPC通道管理示例代码副作用: 4. 接收消息的超时设置示例代码副作用: 5. 增加I/O线程数量示例代码副作用: 6. 异步消息发送(使用`dontwait`标志)示例代码副作用: 7. 其他可以考虑的优化项7.1 立即发送(ZMQ_IM

[轻笔记] ubuntu Shell脚本实现监视指定进程的运行状态,并能在程序崩溃后重启动该程序

根据网上博客实现,发现只能监测进程离线,然后对其进行重启;然而,脚本无法打印程序正常状态的信息。自己通过不断修改测试,发现问题主要在重启程序的命令上(需要让重启的程序在后台运行,不然会影响监视脚本进程,使其无法正常工作)。具体程序如下: #!/bin/bashwhile [ 1 ] ; dosleep 3if [ $(ps -ef|grep exe_name|grep -v grep|