进程间通讯 rcf应用简介

       进程之间通讯的方式有很多中,如文件方式,数据库方式、启动参数、命名管道、匿名管道、消息队列、套接字等,今天我们要介绍的是一个非常好用的开源库Rcf;

RCF特点简介:

1、RCF从2008年发布的第一个正式版本1.0,到现在的3.2.413,经历了多个版本变化,发展的用户包括”爱立信、惠普“等这样全球性的大公司,在网上各种评论中,也是比较不错,是功能比较强大的分布式通信框架,由此可见,从稳定性上来说,RCF目前比较稳定,也比较成熟;

2、RCF基于标准C++,支持Windows、Linux、Unix等操作系统,支持跨平台;

3、多种传输实现(TCP、UDP、Windows 命名管道和 UNIX 本地域套接字)。

4、官网文档中说明,在服务器和客户端上的关键路径上进行零拷贝和零堆分配以提高性能。

5、RCF库非常强大,应用也很广泛。具体详细介绍请浏览官网文档介绍,官网:https://www.deltavsoft.com/doc/index.html

6、编译 下载的官方库有vs工程举例,官网下载地址 https://www.deltavsoft.com/download.html  我下载的是2019.05.11更新的RCF-3.1.328.zip版本;

7、rcf应用很多,本例以发送端和接收端通信为例:

以c++代码举例,发送端是基于vs2015+qt,接收端是基于vs2015;

一、发送端代码

【1】封装通信结构(*必须要序列化通信结构数据)SendStructProtocol.h

#ifndef SEND_STRUCTPROTOCO_H
#define SEND_STRUCTPROTOCO_H
#include <string>
class ControlProtocol
{
public:
	std::string type;
	std::string command;
	float value;

	void serialize(SF::Archive &ar)
	{
		ar & type & command & value ;
	}
};

#endif 

2封装公用调用接口

PublicCallInterface.h

#ifndef INCLUDE_INCLUDEPUBLICCALL
#define INCLUDE_INCLUDEPUBLICCALL
#include <winsock2.h>
#include <QtCore/QMutex>
#include <RCF/Idl.hpp>
#include <SF/vector.hpp>
#include <RCF/RCF.hpp>
#include "SendStructProtocol.h"

#define CALLFONCTION interactiveInterface              //交互接口函数,与服务器对应函数可不同名,但返回值与参数必须相同
RCF_BEGIN(I_DemoService, "I_DemoService")    //此处与服务器绑定的必须一致
RCF_METHOD_V1(void, CALLFONCTION, ControlProtocol &);//初始化绑定交互接口函数
RCF_END(I_DemoService);

static class PublicCallInterface
{
public:
	PublicCallInterface();
	~PublicCallInterface();
	static QMute
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值