c语言mc协议,easymc - C语言开发的简易消息通道库

easymc是一个C语言开发的简易的消息通道库,目前提供请求/回应、订阅/发布两种通信模式,同机器的通信采取IPC方式,跨机的通信采取TCP方式,源码包含开源项目jemalloc库。

代码地址:https://github.com/easymc/easymc

local端使用例子:

struct para{

int device;

int exit;

};

static emc_result_t EMC_CALL OnRecvMsg(void *p){

void *msg=NULL;

struct para *pa=(struct para *)p;

int device=pa->device;

while(!pa->exit){

if(0==emc_recv(device,(void **)&msg)){

//            printf("recv length=%ld\n",emc_msg_length(msg));

if(EMC_SUB==emc_msg_get_mode(msg)){

emc_msg_set_mode(msg,EMC_PUB);

}else if(EMC_REQ==emc_msg_get_mode(msg)){

emc_msg_set_mode(msg,EMC_REP);

}

emc_send(device,msg,0);

emc_msg_free(msg);

}

}

printf("OnRecvMsg exit\n");

return 0;

}

static emc_result_t EMC_CALL OnMonitorDevice(void *p){

struct para *pa=(struct para *)p;

int device=pa->device;

struct monitor_data data={0};

while(!pa->exit){

if(0==emc_monitor(device,&data)){

switch(data.events){

case EMC_EVENT_ACCEPT:

printf("client connected server,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_CLOSED:

printf("client disconnected server,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_SNDSUCC:

//                printf("server send successful,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_SNDFAIL:

//                printf("server send failed,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

}

}

}

return 0;

}

int main(int argc, char* argv[]){

struct para pa={0};

int monitor=1,ch=0;

int device=emc_device();

pa.device=device;

pa.exit=0;

emc_set(device,EMC_OPT_MONITOR|EMC_OPT_CONTROL,&monitor,sizeof(int));

printf("Input a port to bind:");

scanf("%ld",&ch);

if(emc_bind(device,NULL,ch) < 0){

printf("emc_bing fail\n");

}

emc_thread(OnRecvMsg,(void *)&pa);

emc_thread(OnMonitorDevice,(void *)&pa);

printf("Input C or c to close a connection,Q or q to exit\n");

while(1){

ch=getchar();

if('C'==ch || 'c'==ch){

printf("Input connection id:");

scanf("%ld",&ch);

emc_control(device,ch,EMC_CTL_CLOSE);

}else if('Q'==ch || 'q'==ch){

break;

}

}

getchar();

getchar();

pa.exit=1;

emc_destory(device);

getchar();

return 0;

}

remote端使用例子:

struct para{

int device;

int exit;

};

static emc_result_t EMC_CALL OnRecvMsg(void *p){

struct para *pa=(struct para *)p;

int device=pa->device;

void *msg=NULL;

while(!pa->exit){

if(0==emc_recv(device,(void **)&msg)){

printf("recv length=%ld\n",emc_msg_length(msg));

emc_msg_free(msg);

}

}

return 0;

}

static emc_result_t EMC_CALL OnMonitorDevice(void *p){

struct para *pa=(struct para *)p;

int device=pa->device;

struct monitor_data data={0};

while(!pa->exit){

if(0==emc_monitor(device,&data)){

switch(data.events){

case EMC_EVENT_CONNECT:

printf("client connected server,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_CLOSED:

printf("client disconnected server,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_SNDSUCC:

printf("server send successful,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

case EMC_EVENT_SNDFAIL:

printf("server send failed,ip=%s,port=%ld,id=%ld\n",data.ip,data.port,data.id);

break;

}

}

}

return 0;

}

int main(int argc, char* argv[]){

int ch=0;int device=-1;

char ip[16]={0};

int monitor=1,length=0,port=0;

void *msg=NULL;void *msg_=NULL;

struct para pa={0};

device=emc_device();

pa.device=device;

pa.exit=0;

printf("Input serve ip:");

scanf("%s",ip);

printf("Input server port:");

scanf("%ld",&port);

emc_thread(OnMonitorDevice,(void *)&pa);

emc_set(device,EMC_OPT_MONITOR,&monitor,sizeof(int));

printf("Input mode(1-req,8-sub):");

scanf("%ld",&ch);

emc_connect(device,ch,ip,port);

emc_thread(OnRecvMsg,(void *)&pa);

printf("Input send data length[Bytes]:");

scanf("%ld",&length);

if(EMC_REQ==ch){

printf("You choose REQREP mode,type S or s to send data and type Q or q to quit\n");

while(1){

ch=getchar();

if('S'==ch || 's'==ch){

msg=emc_msg_alloc(NULL,length);

emc_msg_set_mode(msg,EMC_REQ);

emc_send(device,msg,0);

emc_msg_free(msg);

}else if('Q'==ch || 'q'==ch){

pa.exit=1;

break;

}

}

}else if(EMC_SUB==ch){

printf("You choose PUBSUB mode,type S or s to send data and type Q or q to quit\n");

while(1){

ch=getchar();

if('S'==ch || 's'==ch){

msg=emc_msg_alloc(NULL,length);

emc_msg_set_mode(msg,EMC_SUB);

emc_send(device,msg,0);

emc_msg_free(msg);

}else if('Q'==ch || 'q'==ch){

pa.exit=1;

break;

}

}

}

getchar();

getchar();

pa.exit=1;

emc_destory(device);

return 0;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/428920.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1006 换个格式输出整数 (15 分)

1006 换个格式输出整数 (15 分)让我们用字母 B 来表示“百”、字母 S 表示“十”&#xff0c;用 12…n 来表示不为零的个位数字 n&#xff08;<10&#xff09;&#xff0c;换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234&#xff0c;因为它有 2…

android 复制字符串,Cocos2dx 复制文本到剪切板(Android 和 ios)

ClipboardManager cm (ClipboardManager) getSystemService(Context.CLIPBOARD_SERVICE);cm.setText(要复制的文本内容);源码分享&#xff1a;Cocos2dxHelper.java 中添加吧import android.content.ClipboardManager; //导入需要的库static public int copyToClipboard(final …

1007 素数对猜想 (20 分)

1007 素数对猜想 (20 分) 让我们定义d ​n ​​ 为&#xff1a;d ​n ​​ p ​n1 ​​ −p ​n ​​ &#xff0c;其中p ​i ​​ 是第i个素数。显然有d ​1 ​​ 1&#xff0c;且对于n>1有d ​n ​​ 是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。 现…

[原创]浅谈移动互联网App兼容性测试

[原创]浅谈移动互联网App兼容性测试 今天要谈的话题&#xff0c;估计各位测试都有感受&#xff0c;移动互联网App兼容性测试&#xff0c;我们到底测试覆盖如何去挑选机型&#xff1f;具体移动App兼容性测试如何开展&#xff1f;是不是应引进像testin这样的第三方来检查覆盖?可…

高仿人人android梦想版终极源码发送,人人Android客户端梦想版发布

人人网梦想版for Android 5.0.1下载(人人网Android客户端)人人网今天发布Android客户端“梦想版”&#xff0c;新版更新的“私信”功能与微信等聊天工具同出一辙&#xff0c;还可以发送语音和大幅表情。其他界面也进行了大幅更新。以下为人人网官方介绍&#xff1a;打开这篇日志…

1008 数组元素循环右移问题 (20 分)

1008 数组元素循环右移问题 (20 分) 一个数组A中存有N&#xff08;>0&#xff09;个整数&#xff0c;在不允许使用另外数组的前提下&#xff0c;将每个整数循环向右移M&#xff08;≥0&#xff09;个位置&#xff0c;即将A中的数据由&#xff08;A ​0 ​​ A ​1 ​​ ⋯A…

JS非空验证

代码如下&#xff1a; <!DOCTYPE html> <html><meta charset"UTF-8"><title></title><head><script language"javascript">function checklogin() {if((myform.user.value ! "")) {if((myform.pwd.va…

android 平板方案,Android平板方案

一、英伟达(NVIDIA) Tegra 2NVIDIA Tegra 2处理器&#xff0c;采用40nm制程制造&#xff0c;集成8个不同功能的处理器&#xff0c;主要包括&#xff1a;两个ARMCortex-A9核心&#xff0c;运行频率1GHz。另外有一个ARM7处理器&#xff0c;一个音频处理器(AudioProcessor)&#x…

1009 说反话 (20 分)

1009 说反话 (20 分) 给定一句英语&#xff0c;要求你编写程序&#xff0c;将句中所有单词的顺序颠倒输出。 输入格式&#xff1a; 测试输入包含一个测试用例&#xff0c;在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成&#xff0c;其中单词是由英文…

1-18Linux内核空间和用户空间

转载请说明出处:http://www.cnblogs.com/zaifeng0108/p/7364411.html OS的接口有两类&#xff1a; GUI&#xff1a;Graphic User Interface GNome&#xff1a;c, gtkKDE: c, qtCLI&#xff1a;Command Line Interface bashzshshcshtcshksh转载于:https://www.cnblogs.com/zaife…

android点击灰色背景图片,android button按键失去焦点和点击后改变背景图片

android button按键得到焦点和点击后改变背景图片我也接受android不久&#xff0c;今天来给同学们分享一下button得到焦点和点击后改变背景图片&#xff0c;其实很简单就是两个事件setOnFocusChangeListener和setOnClickListener就OK了。这是Activity 中的代码。package com.ha…

1010 一元多项式求导 (25 分)

1010 一元多项式求导 (25 分) 设计函数求一元多项式的导数。&#xff08;注&#xff1a;x ​n ​​ &#xff08;n为整数&#xff09;的一阶导数为nx ​n−1 ​​ 。&#xff09; 输入格式: 以指数递降方式输入多项式非零项系数和指数&#xff08;绝对值均为不超过 1000 的整…

android无线充产品,一天售罄!鲁蛋超薄无线快充太火爆 兼容苹果安卓成最大卖点...

3月5日&#xff0c;鲁大师发布了最新智能硬件产品——「鲁蛋超薄无线快充」。这项智能产品同样来自旗下品牌「鲁蛋」&#xff0c;它是一款兼具安卓与苹果的无线充电设备&#xff0c;并且输出功率最高达到10W。鲁蛋无线快充于3月6日凌晨上线京东&#xff0c;下单立减20元&#x…

P2678 [NOIP2015 提高组] 跳石头

P2678 [NOIP2015 提高组] 跳石头 题目背景 一年一度的“跳石头”比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行&#xff0c;河道中分布着一些巨大岩石。组委会已经选择好了两块岩石作为比赛起点和终点。在起点和终点之间&#xff0c;有 NN 块岩石&#xff08;不…

ASP.NET MVC5(一):ASP.NET MVC概览

ASP.NET MVC概览 ASP.NET MVC是一种构建Web应用程序的框架&#xff0c;它将一般的MVC&#xff08;Model-View-Controller&#xff09;模式应用于ASP.NET框架。 ASP.NET MVC模式简介 MVC将Web应用程序划分为三个主要的部分&#xff0c;以下是MSDN给出的定义&#xff1a; 模型&am…

android休眠后恢复线程,关于Android系统休眠后,线程的执行情况

理论上&#xff0c;android系统休眠后&#xff0c;app进程会被挂起&#xff0c;所以相关的执行线程也会被挂起&#xff0c;那些java线程的操作例如:wait&#xff0c;await&#xff0c;sleep&#xff0c;循环阻塞&#xff0c;handler的delay&#xff0c;线程池的delay操作都会被…

1011 A+B 和 C (15 分)

1011 AB 和 C (15 分) 给定区间 [−2 ​31 ​​ ,2 ​31 ​​ ] 内的 3 个整数 A、B 和 C&#xff0c;请判断 AB 是否大于 C。 输入格式&#xff1a; 输入第 1 行给出正整数 T (≤10)&#xff0c;是测试用例的个数。随后给出 T 组测试用例&#xff0c;每组占一行&#xff0c;…

java-上传文件与现实上传文件

项目结构&#xff1a; 项目展示&#xff1a; 数据库&#xff1a; /* SQLyog Ultimate v12.09 (64 bit) MySQL - 5.5.53 : Database - fileupload ********************************************************************* *//*!40101 SET NAMES utf8 */;/*!40101 SET SQL_MODE*…

1012 数字分类 (20 分)

1012 数字分类 (20 分) 给定一系列正整数&#xff0c;请按要求对数字进行分类&#xff0c;并输出以下 5 个数字&#xff1a; A ​1 ​​ 能被 5 整除的数字中所有偶数的和&#xff1b; A ​2 ​​ 将被 5 除后余 1 的数字按给出顺序进行交错求和&#xff0c;即计算 n ​1 ​…

BZOJ2948 : [Poi2001]绿色游戏

维护一个保护集合$S$&#xff0c;表示哪些点$A$可能胜利。 首先将所有绿点加入$S$。 $1.$对于一个不在$S$的$A$点&#xff0c;若它存在某个后继在$S$中&#xff0c;则将其加入$S$。 $2.$对于一个不在$S$的$B$点&#xff0c;若它所有后继都在$S$中&#xff0c;则将其加入$S$。 通…