邮槽通信的进程分为服务端和客户端.服务端创建邮槽,客户端通过邮槽名打开邮槽,获得句柄后可以向邮槽写数据. 邮槽通信是单向通信,只能由客户端向服务端发送数据.下面来看看有关邮槽的几个API

HANDLE WINAPICreateMailslot(

_In_      LPCTSTR lpName,

_In_      DWORDnMaxMessageSize,

_In_      DWORDlReadTimeout,

_In_opt_  LPSECURITY_ATTRIBUTESlpSecurityAttributes

);

功能:创建一个邮槽

参数:  lpName   指定的邮槽名,格式必须为  \\.\mailslot\[path]name

nMaxMessageSize  可以写到邮槽中的单个消息的最大字节数,如果为0则表示可以是任意大小的消息.

lReadTimeout    读取操作可以等待多久,0表示没有可读的消息则直接返回, MAILSLOT_WAIT_FOREVER表示一直等待可读消息.

lpSecurityAttributes  安全属性结构体指针,   可以为NULL

返回值: 如果成功,返回邮槽句柄,服务端通过句柄操作邮槽.如果失败则返回INVALID_HANDLE_VALUE

BOOL WINAPI GetMailslotInfo(
  _In_       HANDLE hMailslot,
  _Out_opt_  LPDWORD lpMaxMessageSize,
  _Out_opt_  LPDWORD lpNextSize,
  _Out_opt_  LPDWORD lpMessageCount,
  _Out_opt_  LPDWORD lpReadTimeout
);

功能:获取有关邮槽的信息

参数: hMailslot  邮槽句柄

lpMaxMessageSize     单个消息的最大字节数, 也可以为NULL

lpNextSize   下一个消息的大小,可以为NULL,为MAILSLOT_NO_MESSAGE表示没有下一个消息

lpMessageCount  等待读取的消息数, 可以为NULL,

lpReadTimeout   等待可读消息的时间, 也可以为NULL

返回值:成功返回非0,失败返回0

BOOL WINAPI SetMailslotInfo(
  _In_  HANDLE hMailslot,
  _In_  DWORD lReadTimeout
);
 

功能:设置等待可读消息的超时时间

服务端通过ReadFile从邮槽中读取数据,客户端通过CreateFile打开邮槽,WriteFile向邮槽写数据。以下是我用Qt做的简单验证程序,由于不熟悉window窗台程序,所以只能用Qt了。

客户端代码

MailSlotClient::MailSlotClient(QWidget *parent, Qt::WFlags flags)
: QDialog(parent, flags)
{
m_pMailSlotNameLbl = new QLabel(tr("MailSlot Name:"),this);
m_pMailSlotNameLEdit = new QLineEdit(this);
m_pMessageText = new QTextEdit(this);
m_pMainLayout = new QGridLayout(this);
m_pSendMessageBtn = new QPushButton(tr("Send Message "),this);
this->setLayout(m_pMainLayout);
m_pMainLayout->addWidget(m_pMailSlotNameLbl,0,0,1,1);
m_pMainLayout->addWidget(m_pMailSlotNameLEdit,0,1,1,1);
m_pMainLayout->addWidget(m_pSendMessageBtn,0,2,1,1);
m_pMainLayout->addWidget(m_pMessageText,1,0,4,4);
connect(m_pSendMessageBtn,SIGNAL(clicked()),this,SLOT(SendMessageSlot()));
//ui.setupUi(this);
} MailSlotClient::~MailSlotClient()
{ } void MailSlotClient::SendMessageSlot()
{
QString name = m_pMailSlotNameLEdit->text();
string szMailSlotName = (string("\\\\.\\mailslot\\") + name.toStdString()).c_str();
//LPSTR szMailSlotName = "\\\\.\\mailslot\\simplemailslot";
HANDLE hFile ;
hFile = CreateFile(szMailSlotName.c_str(),GENERIC_WRITE,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
if (hFile == INVALID_HANDLE_VALUE)
{
QMessageBox::information(this,tr("提示"),tr("打开邮槽失败!"),QMessageBox::Ok);
return ;
}
DWORD dwWriteSize;
string message = m_pMessageText->toPlainText().toStdString();
WriteFile(hFile,message.c_str(),message.size(),&dwWriteSize,NULL);
CloseHandle(hFile);
}

服务端代码:

MailSlotServer::MailSlotServer(QWidget *parent, Qt::WFlags flags)
: QDialog(parent, flags)
{
m_pMailSlotNameLbl = new QLabel(tr("MailSlot Name:"),this);
m_pMailSlotNameLEdit = new QLineEdit(this);
m_pMessageText = new QTextEdit(this);
m_pMainLayout = new QGridLayout(this);
m_pCreateMailSlotBtn = new QPushButton(tr("Create MailSlot "),this);
this->setLayout(m_pMainLayout);
m_pMainLayout->addWidget(m_pMailSlotNameLbl,0,0,1,1);
m_pMainLayout->addWidget(m_pMailSlotNameLEdit,0,1,1,1);
m_pMainLayout->addWidget(m_pCreateMailSlotBtn,0,2,1,1);
m_pMainLayout->addWidget(m_pMessageText,1,0,4,4);
connect(m_pCreateMailSlotBtn,SIGNAL(clicked()),this,SLOT(CreateMailSlot()));
} MailSlotServer::~MailSlotServer()
{ } void MailSlotServer::CreateMailSlot()
{
HANDLE hMailSlot;
QString name = m_pMailSlotNameLEdit->text();
string szMailSlotName = (string("\\\\.\\mailslot\\") + name.toStdString()).c_str();
hMailSlot = CreateMailslot(szMailSlotName.c_str() ,0,MAILSLOT_WAIT_FOREVER,NULL); if (hMailSlot == INVALID_HANDLE_VALUE)
{
QMessageBox::information(this,tr("提示"),tr("创建邮槽失败!"),QMessageBox::Ok);
return ;
} DWORD dwMessageCount = 0;
DWORD dwMessageSize = 0;
DWORD dwReadSize = 0;
bool bFinish =false;
while (TRUE)
{
BOOL bResult = GetMailslotInfo(hMailSlot,NULL,&dwMessageSize,&dwMessageCount,NULL);
if (!bResult)
{
QMessageBox::information(this,tr("提示"),tr("获取邮槽信息失败!"),QMessageBox::Ok);
return ;
}
while (dwMessageCount != 0)
{
char *lpBuffer = new char[dwMessageSize];
memset(lpBuffer,0,dwMessageSize);
ReadFile(hMailSlot,lpBuffer,dwMessageSize,&dwReadSize,NULL); m_pMessageText->setText(QString::fromStdString(lpBuffer));
GetMailslotInfo(hMailSlot,NULL,&dwMessageSize,&dwMessageCount,NULL);
bFinish = true;
}
if (bFinish) //读取完了就返回,不然一直卡住就没法显示接收到的数据了 {
return;
}
}
}

先启动服务端,输入邮槽名,创建邮槽,程序循环等待客户端发来数据。接收到数据后显示。再启动客户端,输入邮槽名,输入要发送的数据,点击发送,数据将显示在服务端。

window API一天一练之邮槽的更多相关文章

  1. 【IPC进程间通讯之中的一个】邮槽MailSlot

    IPC进程间通信+邮槽MailSlot                IPC(Inter-Process Communication.进程间通信).        现代计算机採用虚拟内存机制,为进程提 ...

  2. c++下使用邮槽实现进程间通信

    Windows API提供了邮槽和命名管道两种机制来实现进程间通信,在这里使用C++实现邮槽. 邮槽是Windows提供的一种进程间单向通信的机制,进程中的一方只能读取(或写入)数据,而另一方只能写入 ...

  3. Windows网络编程笔记3 ---- 邮槽和命名管道

    邮槽和命名管道的使用方法也很简单,只需几个有限的函数就可以实现双方的通信. 第三.邮槽 邮槽----进程间通信机制. 通过邮槽客户进程可以将消息通过广播给一个或多个服务进程.这是一个单向通信机制,缺点 ...

  4. [C++] socket -7 [邮槽]

    ::利用邮槽实现windons进程通信 ::一般情况下CreateMailslot()常被使用在进程通信的服务器上,在客户端则是用函数CreateFile()打开指定的邮槽之后进行相关的操作. ::将 ...

  5. [Win]进程间通信——邮槽Mailslot

    进程间通信 进程的地址空间是私有的.出于安全性的目的,如果一个进程不具有特殊的权限,是无法访问另外一个进程的内存空间的,也无法知道内存中保存的数据的意义.但是在一些具体的应用情况下需要多个进行相互配合 ...

  6. windows 邮槽mailslot 在服务程序内建立后客户端无权限访问(GetLastError() == 5)的问题

    邮槽创建在服务程序内,可以创建成功, 但外部客户端连接时 m_hMailslot = CreateFile("\\\\.\\mailslot\\zdpMailslot",GENER ...

  7. 邮槽 匿名管道 命名管道 剪贴板 进程通讯 转自http://www.cnblogs.com/kzloser/archive/2012/11/04/2753367.html#

    邮槽 通信流程: 服务器 客户端 注意: 邮槽是基于广播通信体系设计出来的,它采用无连接的不可靠的数据传输 邮槽可以实现一对多的单向通信,我们可以利用这个特点编写一个网络会议通知系统,而且实现这一的系 ...

  8. ASP.NET MVC的Web Api的实练

    学习ASP.NET MVC一年多来,现在该学学Web Api了.API与ASP.NET MVC的Controller差不多.前者只是返回数据序列化和发送给客户端: 后者返回View或Render Vi ...

  9. C#:通过Window API接口实现WiFi

    1.获取Mac地址 //WiFi通知回调 private WlanApi.WLAN_NOTIFICATION_CALLBACK _notificationCallback; this._notific ...

随机推荐

  1. 解决Windows10下无法对docker容器进行端口访问(端口映射的问题)

    解决Windows10下无法对docker容器进行端口访问(端口映射的问题) 问题详情 在Windows10系统服务器中安装了docker和docker-compose 并尝试在其中运行Nginx服务 ...

  2. List,Set的区别

    1.List,Set都是继承自Collection接口2.List特点:元素有放入顺序,元素可重复 ,Set特点:元素无放入顺序,元素不可重复(注意:元素虽然无放入顺序,但是元素在set中的位置是有该 ...

  3. 卡在 构建 gradle 项目信息

    之所以卡死是因为Android Studio在初次构建的时候,会联网进行gradle目录的更新操作.断网之后就不会去主动更新了. 断网. 打开项目. 把 gradle 改成 使用当地. ======= ...

  4. java自动给版本升级,遇9变0且前面一个版本加1

    /** * 自动升级版本号,版本号+1 * @param version * @return */ private String autoUpgradeVersion(String version){ ...

  5. 应用通信-方案一:RestTemplate

    @RestController public class ClientController { @Autowired private LoadBalancerClient loadBalancerCl ...

  6. RabbitMQ消息交换模式简介

    RabbitMQ是AMQP的一个典型实现,它消息发布者的消息发布到Exchange上,同时需要制定routingkey,可以通过指定交换机的不同模式实现不同的行为. RabbitMQ提供了四种Exch ...

  7. PHP 依赖注入(DI) 和 控制反转(IoC)

    要想理解 PHP 依赖注入 和 控制反转 两个概念,就必须搞清楚如下的两个问题: DI —— Dependency Injection 依赖注入 IoC —— Inversion of Control ...

  8. [转]LRU缓存实现(Java)

    LRU Cache的LinkedHashMap实现 LRU Cache的链表+HashMap实现 LinkedHashMap的FIFO实现 调用示例 LRU是Least Recently Used 的 ...

  9. DOM对象之document对象

    DOM对象:当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). HTML DOM 模型被构造为对象的树. 打开网页后,首先看到的是浏览器窗口,即顶层的win ...

  10. Win10年度更新开发必备:VS2015 Update 1正式版下载汇总

    微软在12月1日发布了Visual Studio 2015 Update 1 .在MSDN中微软也提供下载,而且MSDN的Visual Studio 2015 Update 1与官方免费下载的文件是一 ...