多进程通信之管道demo

本文记录了一次学习多进程通信的过程,通过C++编程实现了一个简单的管道通信示例。代码展示了从server端发送消息到client,client接收到消息并显示,server退出后,client不再执行。该实验参考了网络上的相关资源进行改编,适用于初步理解多进程间的通信机制。
摘要由CSDN通过智能技术生成

学习了一下多进程之间通信,记录一下:

#pragma once

#include <stdio.h>
#include <tchar.h>

#include <iostream>
#include <Windows.h>
#include <string>

#include <memory>
#include "stdafx.h"

enum PIPEUSERTYPE{
   
	USER_CLIENT, //客户端
	USER_SERVER, //服务端
};

class PipeIPC{
   
public:
	PipeIPC();
	~PipeIPC();

	bool InitPipeIPC(std::string pipe_name, PIPEUSERTYPE states); //初始化管道通信

	//读写数据
	bool WriteData(std::string datas); //写入数据
	bool ReadData(std::string& datas, bool& isPipeEnd); //读取数据

private:
	std::string m_pipe_name;
	HANDLE m_hPipeHandle;
	PIPEUSERTYPE m_state; //状态设置
};
#include "stdafx.h"
#include "PipeDemo.h"
using namespace std;

//实现
PipeIPC::PipeIPC()
{
   
	m_pipe_name = ""; //设置空
	m_hPipeHandle = nullptr;
	m_state = USER_CLIENT; //默认为客户端
}

PipeIPC::~PipeIPC()
{
   
	DisconnectNamedPipe(m_hPipeHandle);
	CloseHandle(m_hPipeHandle);//关闭句柄
}

bool PipeIPC::InitPipeIPC(std::string pipe_name, PIPEUSERTYPE states)
{
   
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值