进程间通信命名管道中CallNamedPipeW函数怎么用?

jren_nanjing 2013-12-11 06:48:43
服务端
CreateNamedPipeW
ConnectNamedPipe

客户端
CallNamedPipeW

只用这3个有关管道的函数,外加ReadFile这些函数可以实现进程间通信吗,可以的话给个demo如何?

相关资料:
http://blog.csdn.net/timewolf/article/details/2857502
...全文
193 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
derekrose 2013-12-12
  • 打赏
  • 举报
回复
版主大哥 2013-12-12
  • 打赏
  • 举报
回复
参考下http://blog.163.com/ssb_it/blog/static/44876165200852884527255/
赵4老师 2013-12-12
  • 打赏
  • 举报
回复
参考Microsoft SDK\samples\winbase\Service\*.*
jren_nanjing 2013-12-12
  • 打赏
  • 举报
回复
引用 2 楼 max_min_ 的回复:
加个sleep, 不然的话程序运行起来马上就结束了!
注释掉Sleep的话也不是直接结束的,GetLastError提示231(所有管道范例都在使用中)。
max_min_ 2013-12-11
  • 打赏
  • 举报
回复
加个sleep, 不然的话程序运行起来马上就结束了!
jren_nanjing 2013-12-11
  • 打赏
  • 举报
回复
我这样写了一个demo,不知道为什么两边都要加上Sleep()才好使。不过好歹算是会用这个函数了。

#include<stdio.h>
#include<windows.h>

int main()
{
    HANDLE hPipe = CreateNamedPipeW(L"\\\\.\\pipe\\PipeTest",3,6,0xff,0,0,0,NULL);
    
    ConnectNamedPipe(hPipe,NULL);
    
    Sleep(100);
    DWORD dwWrite = 0;
    WCHAR WriteBuf[2000] = {L"abc"};
    WriteFile(hPipe, (char*)WriteBuf, 100, &dwWrite, NULL);

    CloseHandle(hPipe);
    return 0;
}

#include<stdio.h>
#include<windows.h>

int main()
{
    char WriteBuf[2000]={0};  
    WCHAR ReadBuf[2000]={0};
    DWORD BytesRead=0;
    BOOL  bFlag=FALSE;
        
    bFlag = CallNamedPipeW(L"\\\\.\\pipe\\PipeTest",WriteBuf,sizeof(WriteBuf),ReadBuf,sizeof(ReadBuf),&BytesRead,NMPWAIT_WAIT_FOREVER);
    Sleep(1000);
    wprintf(L"ErrorCode:%d\n",GetLastError());
    wprintf(L"WriteBuf:%s \nReadBuf:%s\n",WriteBuf,ReadBuf);
    
    return 0;
}

64,648

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧