进程通信

  • 使用 WM_COPYDATA

    • 客户端(发送端)

      // 1. 找到窗口程序
      HWND hWnd = FindWindow(NULL, L"Window1");

      // 2. 构建一个 COPYDATASTRUCT 结构体
      COPYDATASTRUCT CopyData = { };
      CopyData.dwData = 0x100; // 要传递的一个4字节数据,通常是类型
      CopyData.cbData = 0x0A; // 存储数据的缓冲区大小
      CopyData.lpData = (LPVOID)"Hello15pb"; // 指向要发送的数据

      // 3. 发送数据给对象的窗口
      SendMessage(hWnd, WM_COPYDATA, NULL, (LPARAM)&CopyData);
    • 服务端(接收端)

      // 响应 WM_COPYDATA 消息
      case WM_COPYDATA:
      {
      // 1. 获取 LPARAM 只想的内容
      auto CopyData = (PCOPYDATASTRUCT)lParam;

      // 2. 输出内容
      MessageBoxA(hWnd, (LPCSTR)CopyData->lpData, "WM_COPYDATA", MB_OK);

      break;
      }
  • 使用 邮槽内核对象

    • 客户端(发送端)

      // 1. 打开邮槽对象
      HANDLE hFile = CreateFile(
      L"\\\\.\\mailslot\\Sample", // 邮槽名称
      GENERIC_WRITE, // 读写属性
      FILE_SHARE_READ, // 共享属性
      NULL, // 安全属性
      OPEN_EXISTING, // 打开方式
      FILE_ATTRIBUTE_NORMAL, // 标志位
      NULL); // 文件模板(默认留空)

      // 2. 向mailslot写入
      DWORD dwWritten = ;
      WriteFile(hFile, "Hello", , &dwWritten, NULL);

      // 3. 结束
      printf("已经向邮槽写入信息!\n");
      CloseHandle(hFile);
    • 服务端(接收端)

      // 1. 创建邮槽对象
      HANDLE hSlot = CreateMailslot(
      L"\\\\.\\mailslot\\Sample", // 邮槽名
      , // 不限制消息大小
      MAILSLOT_WAIT_FOREVER, // 无超时
      NULL); // 安全属性

      // 2. 循环读取邮槽信息
      while (true)
      {
      // 2.1 获取邮槽消息数量
      DWORD dwMsgCount = , dwMsgSize = ;

      // 2.2 获取邮槽信息
      GetMailslotInfo(
      hSlot, // 邮槽句柄
      NULL, // 无最大消息限制
      &dwMsgSize, // [ 下一条消息的大小 ]
      &dwMsgCount, // [ 消息的总数量 ]
      NULL); // 无时限

      // 2.3 如果没有接收到消息,那么久休眠一阵子
      if (dwMsgSize == MAILSLOT_NO_MESSAGE)
      {
      Sleep();
      continue;
      }

      // 2.4 循环获取全部消息(有可能不只一条)
      while (dwMsgCount)
      {
      DWORD dwRet = ;
      PBYTE lpBuffer = new BYTE[dwMsgSize]{ };

      // 2.5 读取邮槽中的信息
      if (!ReadFile(hSlot, lpBuffer, dwMsgSize, &dwRet, NULL))
      {
      printf("ReadFile函数执行失败,错误码:%d.\n", GetLastError());
      delete[] lpBuffer;
      return ;
      }
      printf("邮槽的内容: %s\n", lpBuffer);

      // 2.6 计算剩余的消息数
      GetMailslotInfo(hSlot, (LPDWORD)NULL, &dwMsgSize, &dwMsgCount, nullptr);
      delete[] lpBuffer;
      }

      }

Windows提高_1.4进程通信的更多相关文章

  1. Windows提高_1.2遍历进程、遍历模块

    进程 什么是进程? 通俗的来讲,进程就是一个运行中的程序,最少包含一个虚拟空间,通常是 4 GB大小,一组提供数据和代码的模块,通产是 dll 和 exe 文件,一个进程内核对象和最少一个线程. 进程 ...

  2. Windows提高_1.3文件操作

    文件操作 不带句柄的文件操作 // 1. 拷贝文件,第三个参数为 FALSE 表示会覆盖 // CopyFile(L"D:\\1.txt", L"E:\\2.txt&qu ...

  3. Windows提高_1.1内核对象

    内核对象 什么是内核对象? 内核对象本质上是一个结构体,我们不能直接的操作一个内核对象,需要通过操作系统提供的一系列函数和我们使用的内核对象句柄对它进行一系列的修改. 如何操作内核对象? 创建一个内核 ...

  4. 进程以及进程通信(IPC)类型

    这里用我有限的知识来解释同时参考了一些其他博主的子类,希望能给与一部分入门的朋友一个清晰的理解,有问题之处还请指出 首先简单谈一下什么是进程? 答:进程是装入内存运行的程序段,是许多的系统对象拥有权的 ...

  5. Windows线程+进程通信

    一 Windows线程进程 1)定义 按照MS的定义, Windows中的进程简单地说就是一个内存中的可执行程序, 提供程序运行的各种资源. 进程拥有虚拟的地址空间, 可执行代码, 数据, 对象句柄集 ...

  6. Windows进程通信 -- 共享内存(1)

    共享内存的方式原理就是将一份物理内存映射到不同进程各自的虚拟地址空间上,这样每个进程都可以读取同一份数据,从而实现进程通信.因为是通过内存操作实现通信,因此是一种最高效的数据交换方法. 共享内存在 W ...

  7. Windows进程通信 -- 共享内存

    享内存的方式原理就是将一份物理内存映射到不同进程各自的虚拟地址空间上,这样每个进程都可以读取同一份数据,从而实现进程通信.因为是通过内存操作实现通信,因此是一种最高效的数据交换方法. 共享内存在 Wi ...

  8. Windows进程通信之一看就懂的匿名管道通信

    目录 进程通信之一看就懂的匿名管道通信 一丶匿名管道 1.1何为匿名管道 1.2创建匿名管道需要注意的事项 1.3 创建匿名管道需要的步骤 1.4代码例子 1.5代码运行截图 进程通信之一看就懂的匿名 ...

  9. Windows进程通信-共享内存空间

    三个模块 1,game.exe,三个方法,控制台输入指令('A','B','R')分别控制三个方法的调用: 2,WGDll.dll,要注入到game进程中的dll文件: 3,myconsole.exe ...

随机推荐

  1. 【Unix编程】进程间通信(IPC)

    进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息.IPC的方式通常有管道(包括无名管道和命名管道).消息队列.信号量.共享存储.Socket. ...

  2. java的输入输出流(一)

    java中i/o流是java中核心的一部分,曾经学过.可是理解不够深入,渐渐的也就忘了,如今在从新学习下java的io处理,写下我学习的笔记.便于记忆,和总结归纳: 本文原创,转载请注明:http:/ ...

  3. GSON学习笔记之初识GSON

    引用"JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,採用全然独立于语言的文本格式.为Web应用开发提供了一种理想的数据交换格式. " ...

  4. js 对有“命名空间”的表单做深度解析

    问题描写叙述:一个大表单中,可能包括几十个字段.这些字段在数据库中的映射非常可能不在一张表中,为了降低后台操作的工作量,我们应该在前台提交的时候对数据做初步处理. 举例说明: watermark/2/ ...

  5. 【OI】关于快速幂的简单理解

    都知道算某个数的幂需要线性的复杂度,为了优化复杂度,就出现了所谓的快速幂. 快速幂的代码很短,但是要原理需要一点心思. 首先,我们知道, a^b = a^c * a^d (c+d=b) 那么,不就可以 ...

  6. 在64位的ubuntu 14.04 上开展32位Qt 程序开发环境配置(pro文件中增加 QMAKE_CXXFLAGS += -m32 命令)

    为了能中一个系统上开发64或32位C++程序,费了些周折,现在终于能够开始干过了.在此记录此时针对Q5.4版本的32位开发环境配置过程. 1. 下载Qt 5.4 的32位版本,进行安装,安装过程中会发 ...

  7. go3--常量和类型转换

    /* Go中不存在隐式转换,所有类型转换必须显式声明 转换只能发生在两种相互兼容的类型之间 类型转换的格式: <ValueA> [:]= <TypeOfValueA>(< ...

  8. CANopen——总线基本知识

    1. 总线标准 2. 获取索引和子索引 2fh,2bh,23h,40h等,是不是对应cs的不同值: 主站1280h的对象字典?1280h-sub2,得到client的COB-ID值: 根据收到的m-& ...

  9. flask的nocache防止js不刷新

    原文:http://librelist.com/browser/flask/2011/8/8/add-no-cache-to-response/#952cc027cf22800312168250e59 ...

  10. 利用JProfile 7分析内存OOM

    今天发现一个OOM问题,想来可能是有部分内存没有正确释放导致的 于是想到了之前使用的JProfile来分析一下 由于大概知道哪个类没有释放,可以在Memory Views里看一下对应的类有多少实例来确 ...