进程间传递消息(发送和接收系统消息)

{
  2002.07.22
  关于如何发送和接收系统消息
  作者:王珍义
  nickname:LargeWang(老王)
  QQ: 33728007
  欢迎光临鹏业软件 www.pengesoft.com.cn

  以下代码Delphi7.0通过,编译后启动两个进程,然后在一个窗口中点击Button1试试。
}

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    Msg: LongInt;
    { Private declarations }
  protected
    procedure WndProc(var Message: TMessage); override;
  public

    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.FormCreate(Sender: TObject);
begin
  Msg := RegisterWindowMessage('wm_mymessage');
  Self.BringToFront;
end;

procedure TForm1.WndProc(var Message: TMessage);
begin
  if Message.Msg = Msg then begin
    Caption := '';
    ShowMessage('收到消息了');
  end
  else begin
    inherited;
  end;
end;

procedure TForm1.Button1Click(Sender: TObject);
var
  M: TMessage;
  B: DWord;
begin
  M.Msg := Msg;
  B := BSM_ALLCOMPONENTS;
  BroadcastSystemMessage(BSF_POSTMESSAGE, @B , M.Msg, M.WParam, M.LParam );
end;

end.


窗口文件
object Form1: TForm1
  Left = 192
  Top = 107
  Width = 696
  Height = 480
  Caption = 'Form1'
  Color = clBtnFace
  Font.Charset = DEFAULT_CHARSET
  Font.Color = clWindowText
  Font.Height = -11
  Font.Name = 'MS Sans Serif'
  Font.Style = []
  OldCreateOrder = False
  OnCreate = FormCreate
  PixelsPerInch = 96
  TextHeight = 13
  object Button1: TButton
    Left = 204
    Top = 84
    Width = 75
    Height = 25
    Caption = 'Button1'
    TabOrder = 0
    OnClick = Button1Click
  end
end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
下面是一个简单的MPI程序示例,用于在进程发送消息: ```c #include <mpi.h> #include <stdio.h> int main(int argc, char** argv) { int rank, size, tag = 0; char message[100]; MPI_Status status; // 初始化MPI环境 MPI_Init(&argc, &argv); // 获取进程的排名 MPI_Comm_rank(MPI_COMM_WORLD, &rank); // 获取进程数量 MPI_Comm_size(MPI_COMM_WORLD, &size); if (rank == 0) { // 如果进程是0号进程,则发送消息给1号进程 sprintf(message, "Hello, process 1! This is process 0."); MPI_Send(message, strlen(message) + 1, MPI_CHAR, 1, tag, MPI_COMM_WORLD); } else if (rank == 1) { // 如果进程是1号进程,则接收从0号进程发送消息 MPI_Recv(message, 100, MPI_CHAR, 0, tag, MPI_COMM_WORLD, &status); printf("Process 1 received message: %s\n", message); } // 终止MPI环境 MPI_Finalize(); return 0; } ``` 这个程序中,进程0发送了一条消息进程1,进程1接收到了这条消息并打印出来。MPI_Send和MPI_Recv函数是用于发送接收消息的,它们有一些参数需要注意: - 发送方使用MPI_Send函数来发送消息,参数包括消息内容、消息长度、接收进程的排名、消息的标签(用于区分不同类型的消息)以及通信域(可以是MPI_COMM_WORLD,表示所有进程的通信)。 - 接收方使用MPI_Recv函数来接收消息,参数包括消息缓冲区、消息缓冲区的长度、发送进程的排名、消息的标签、通信域以及一个MPI_Status结构体,用于存储接收到的消息的一些元数据,如消息的长度、发送方的排名等。 在使用MPI编程时,需要注意的一个重要问题是消息传递的顺序。MPI_Send和MPI_Recv函数都是阻塞调用,也就是说当一个进程调用MPI_Send函数发送消息时,该函数不会立即返回,直到接收进程调用MPI_Recv函数接收到该消息为止。因此,在编写MPI程序时,需要保证消息发送接收的顺序是正确的,否则可能会出现死锁等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

largewang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值