C#进程间通信--API传递参数(SendMessage)

简介: 原文 C#进程间通信--API传递参数(SendMessage)     我们不仅可以传递系统已经定义好的消息,还可以传递自定义的消息(只需要发送消息端和接收消息端对自定义的消息值统一即可)。下面的发送和接收端同时演示了系统消息和自定义的消息。

原文 C#进程间通信--API传递参数(SendMessage) 

 

 我们不仅可以传递系统已经定义好的消息,还可以传递自定义的消息(只需要发送消息端和接收消息端对自定义的消息值统一即可)。下面的发送和接收端同时演示了系统消息和自定义的消息。消息统一采用4位16进制的数。
1.系统消息使用的是0x0100(WM_KEYDOWN);0x0000--0x0400是系统自定义的消息,其中0x0000为WM_NULL,0x0400为WM_USER。0x0400以后的数值我们可以作为自定义的消息值。(见附录)
2.自定义消息Message,代码如下:
 

点击(此处)折叠或打开

  1. class Message
  2.     {
  3.         public const int USER = 0x0400;
  4.         public const int WM_TEST = USER + 101;
  5.         public const int WM_MSG = USER + 102;
  6.     }

3.接收端和发送端
接收端Form1:
 

点击(此处)折叠或打开

  1. public partial class Form1 : Form
  2.     {
  3.         public Form1()
  4.         {
  5.             InitializeComponent();
  6.         }
  7.         [DllImport("User32.dll", EntryPoint = "SendMessage")]
  8.         private static extern int SendMessage(IntPtr hWnd, int msg, uint wParam, uint lParam);
  9.         //[DllImport("MessageDLL.dll", EntryPoint = "StartSendMessage")]//MessageDLL找不到
  10.         //private static extern int StartSendMessage(IntPtr hWnd);
  11.         //自己触发自定义消息
  12.         private void button1_Click(object sender, EventArgs e)
  13.         {
  14.             SendMessage(this.Handle, Message.WM_TEST, 100, 200);
  15.         }
  16.         private void button2_Click(object sender, EventArgs e)
  17.         {
  18.             //StartSendMessage(this.Handle);
  19.         }
  20.         //响应和处理自定义消息
  21.         protected override void DefWndProc(ref System.Windows.Forms.Message m)
  22.         {
  23.             string message;
  24.             switch (m.Msg)
  25.             {
  26.                 case Message.WM_TEST://处理消息
  27.                     message = string.Format("收到从应用程序发出的消息!参数为:{0}, {1}", m.WParam, m.LParam);
  28.                     MessageBox.Show(message);
  29.                     break;
  30.                 //case Message.WM_MSG:
  31.                 // message = string.Format("收到从DLL发出的消息!参数为:{0}, {1}", m.WParam, m.LParam);
  32.                 // MessageBox.Show(message);
  33.                 // break;
  34.                 default:
  35.                     base.DefWndProc(ref m);
  36.                     break;
  37.             }
  38.         }
  39.         private void Form1_KeyDown(object sender, KeyEventArgs e)
  40.         {
  41.             this.label1.Text = e.KeyValue.ToString();
  42.         }
  43.     }

发送端Form2:button1启动接收端,button2关闭接收端,button3传递系统消息和自定义的消息。
 

点击(此处)折叠或打开

  1. public partial class Form1 : Form
  2.     {
  3.         [DllImport("User32.dll", EntryPoint = "SendMessage")]
  4.         private static extern int SendMessage(IntPtr hWnd, int msg, int wParam, int lParam);
  5.         //[DllImport("MessageDLL.dll", EntryPoint = "StartSendMessage")]//MessageDLL找不到
  6.         //private static extern int StartSendMessage(IntPtr hWnd);
  7.         //internal string local = "this is a local internal";
  8.         public Form1()
  9.         {
  10.             InitializeComponent();
  11.         }
  12.         //ClassLibrary1.Class1 cla = new ClassLibrary1.Class1();
  13.         ProcessStartInfo startInfo = new ProcessStartInfo();
  14.         Process pro = new Process();
  15.         private void Form1_Load(object sender, EventArgs e)
  16.         {
  17.             startInfo.FileName = @"F:\Projects\WindowsFormsApplication1\WindowsFormsApplication1\bin\Debug\WindowsFormsApplication1.exe";
  18.             pro.StartInfo = startInfo;
  19.         }
  20.         private void button1_Click(object sender, EventArgs e)
  21.         {
  22.             pro.Start();
  23.         }
  24.         private void button2_Click(object sender, EventArgs e)
  25.         {
  26.             pro.Kill();
  27.         }
  28.         private void button3_Click(object sender, EventArgs e)
  29.         {
  30.             IntPtr hWnd = pro.MainWindowHandle;
  31.             int data = Convert.ToInt32(this.textBox1.Text);
  32.             SendMessage(hWnd, 0x0100, data, 0);
  33.             SendMessage(hWnd, Message.WM_TEST, 300, 300);
  34. }

4.界面显示:
点击button1:
 
左侧窗体为发送端,右侧窗体为接收端。
左侧窗体在文本框中输入数值,然后点击button2后,左右窗体显示如下:
 
 
4.关于消息驱动
现在VS上已经由事件驱动取代了消息驱动,不过像消息驱动还是在进程间通信常用的。此外 本来试着通过控制台应用程序向窗体发送消息,没有发送成功(如果有高人解决了,麻烦告诉me一下下哈)。不过一般消息发送与处理都是窗口之间进行的。
5.附录:系统消息
 
6.链接资料网站
SendMessage和PostMessage函数:http://blog.csdn.net/sbz0409/article/details/3772965
目录
相关文章
|
5月前
|
存储 监控 算法
电脑监控管理中的 C# 哈希表进程资源索引算法
哈希表凭借O(1)查询效率、动态增删性能及低内存开销,适配电脑监控系统对进程资源数据的实时索引需求。通过定制哈希函数与链地址法冲突解决,实现高效进程状态追踪与异常预警。
262 10
|
6月前
|
JSON 监控 API
京东商品数据获取新姿势:商品列表API参数全解析
京东商品列表API是京东开放平台的核心接口,支持开发者高效获取商品名称、价格、销量等信息,适用于电商分析、价格监控等场景。提供关键词搜索、分类筛选、价格区间、排序及分页功能,支持HTTPS请求,数据实时更新,单次可查询最多200个SKU,助力电商应用开发。
|
6月前
|
JSON 监控 供应链
京东商品详情API参数构造指南:必填参数与自定义字段配置
京东商品详情API由京东开放平台提供,支持获取商品基础信息、价格库存、SKU规格等120+字段,适用于价格监控、库存管理等场景。接口采用HTTPS协议、JSON格式,数据延迟≤30秒,支持高并发。提供Python请求示例,便于快速接入。
|
11月前
|
自动驾驶 程序员 API
告别重复繁琐!Apipost参数描述库让API开发效率飙升!
在API开发中,重复录入参数占用了42%的时间,不仅效率低下还易出错。Apipost推出的参数描述库解决了这一痛点,通过智能记忆功能实现参数自动填充,如版本号、分页控制、用户信息等常用字段,大幅减少手动输入。支持Key-Value与Raw-Json格式导入,一键提取响应结果至文档,将创建20参数接口文档时间从18分钟缩短至2分钟。相比Postman需手动搜索变量,Apipost的参数复用响应速度仅0.3秒,且支持跨项目共享与实时纠错,真正实现“一次定义,终身受益”。
|
设计模式 开发框架 安全
C# 一分钟浅谈:GraphQL API 与 C#
本文介绍了 GraphQL API 的基本概念及其优势,并通过 C# 实现了一个简单的 GraphQL 服务。GraphQL 是一种高效的 API 查询语言,允许客户端精确请求所需数据,减少不必要的数据传输。文章详细讲解了如何使用 `GraphQL.NET` 库在 C# 中创建和配置 GraphQL 服务,并提供了常见问题的解决方案和代码示例。
378 4
|
8月前
|
供应链 数据挖掘 API
1688商品详情API全字段解析:从基础参数到SKU深度挖掘
1688商品详情API为开发者提供高效获取商品信息的官方通道,支持自动化获取标题、价格、库存等核心数据,适用于电商开发、数据分析及供应链管理。接口支持灵活参数配置,并提供Python调用示例,便于快速集成与应用。
|
8月前
|
监控 供应链 API
1688商品列表API全参数指南:从基础搜索到高级筛选
1688商品列表API是阿里巴巴B2B平台的核心接口,支持关键词搜索、高级筛选、排序与分页功能,适用于选品、价格监控等场景。数据规范、稳定高效,日均调用量大。提供Python示例代码,便于快速接入与扩展应用。
|
开发框架 .NET API
RESTful API 设计与实现:C# 开发者的一分钟入门
【10月更文挑战第5天】本文从零开始,介绍了如何使用 C# 和 ASP.NET Core 设计并实现一个简单的 RESTful API。首先解释了 RESTful API 的概念及其核心原则,然后详细说明了设计 RESTful API 的关键步骤,包括资源识别、URI 设计、HTTP 方法选择、状态码使用和错误处理。最后,通过一个用户管理 API 的示例,演示了如何创建项目、定义模型、实现控制器及运行测试,帮助读者掌握 RESTful API 的开发技巧。
721 7
|
11月前
|
JSON 监控 API
1688 商品列表 API 深度拆解:从参数配置到数据获取
1688 是重要的批发采购平台,其商品列表 API 接口为开发者、商家和数据分析人员提供批量获取商品基础信息(如名称、价格、销量等)的能力。该接口支持市场调研、竞品分析等场景,助力商业决策与效率提升。接口基于 HTTPS 协议,采用 GET 或 POST 请求方式,需提供通用参数(如 app_key、timestamp 等)和业务参数(如 category_id、page_no 等)。响应数据以 JSON 格式返回,包含商品详情及分页信息。
352 13
|
Java API PHP
阿里巴巴参数获取API
阿里巴巴的参数获取API流程包括:1. 注册并认证开发者账号;2. 创建应用,获取API密钥;3. 阅读API文档,了解请求参数和返回格式;4. 编写代码调用API,如使用Python请求商品详情;5. 注意API类型及其参数,遵守数据使用规则和法律法规。