MOOS学习笔记1——HelloWorld
MOOS学习笔记1——HelloWorld
例程
/*
* @功能:通讯客户端的最简单程序,向MOOSDB发送名为"Greeting"
* 数据"Hello",并向MOOSDB订阅该信息,接收信息后显示
* 出来
*/
/*
* @功能:插入通讯类头文件
* @介绍:MOOSAsyncCommClient与DB连接以后启动两个不同步的读写线程,
* 极大的减少了时间延迟。
*/
#include"MOOS/libMOOS/Comms/MOOSAsyncCommClient.h"
/*
* @功能:bool Fn(void * pParam)型函数,作为SetOnConnectCallBack()函数的
* 初始参数,在与服务器连接时订阅变量使用。
*/
bool OnConnect(void *pParam){
/*
* reinterpret_cast是强制类型转换符!用来处理无关类型转换,重新解释底层的编码;
* 转换空指针为CMOOSCommClient类型的指针
* CMOOSCommClient为MOOS最重要的类之一,单线程的最初的通讯类
*/
CMOOSCommClient *pC=reinterpret_cast<CMOOSCommClient*>(pParam);
//第一个参数为订阅通知的变量名
//第二个参数为订阅信息到来的最小时间间隔,为0表示以最大速度获取
pC->Register("Greeting",0.0);
return true;
}
//主函数形参C++ primer P196
//第二个参数argv是元素为字符串指针的数组,第一个元素(编号为0)为函数名或空字符串,最后一个元素值为0
//第一个参数argc为数组中字符串的数量,实际输入的字符串数量,值为编号的最大值,即去掉0值的剩下的字符串数量
int main(int argc,char *argv[]){
//初始化通讯
MOOS::MOOSAsyncCommClient Comms;
//调用用户的函数订阅变量通知,第一个参数为函数指针形参,
//第二个参数为传递给用户函数的形参
//输入函数名自动转换为函数指针,
//函数原型为void SetOnConnectCallBack ( bool (* pfn )( void * pParamCaller ),void * pCallerParam );
Comms.SetOnConnectCallBack(OnConnect,&Comms);
//启动客户端线程,告知客户端运行MOOSDB的机器的名字和地址,
//以及MOOSDB的端口,给客户端一个名字。
//最后一个参数指定每秒与MOOSDB通讯多少次,默认为5。
Comms.Run("localhost",9000,"EX10");
//MOOSMSG_LIST是std :: list <CMOOSMsg>的别名,
//list为双向链表容器,类似于vector,CMOOSMsg用于打包moos数据。
//CMOOSMsg是一个类
MOOSMSG_LIST M;
for(;;){
//暂停当前的线程1000毫秒
MOOSPause(1000);
//发送数据,变量名为Greeting,变量值为Hello
Comms.Notify("Greeting","Hello");
//取回客户端工作线程内已准备好的数据
Comms.Fetch(M);
//表示迭代器类型
MOOSMSG_LIST::iterator q;
//begin(),end(),返回迭代器类型,end()迭代器返回最后一个元素
//迭代器不要用<>号,用== !=
for(q=M.begin();q!=M.end();q++){
//输出消息的总结
q->Trace();
}
}
return 0;
}
MOOS学习笔记1——HelloWorld的更多相关文章
- MOOS学习笔记2——HelloWorld回调
MOOS学习笔记2--HelloWorld回调 例程 #include "MOOS/libMOOS/Comms/MOOSAsyncCommClient.h" bool OnConn ...
- Spring MVC 学习笔记一 HelloWorld
Spring MVC 学习笔记一 HelloWorld Spring MVC 的使用可以按照以下步骤进行(使用Eclipse): 加入JAR包 在web.xml中配置DispatcherServlet ...
- MOOS学习笔记4——独立线程不同回调
MOOS学习笔记4--独立线程不同回调 /** * @fn 独立线程不同回调 * @version v1.0 * @author */ #include "MOOS/libMOOS/Comm ...
- MOOS学习笔记3——命令行
MOOS学习笔记3--命令行 例程 /** * @code A simple example showing how to use a comms client问问怎么样 */ #include &q ...
- U3D学习笔记1: HelloWorld
Unity 版本: 5.3.5.f1 Hello World工程 1.新建工程 HelloWorld U3D可选2D和3D游戏 2.新建C#脚本文件 在project栏的assets目录右键-&g ...
- cocos2d-x 2.1.4学习笔记之HelloWorld分析
下面截图是HelloWorld项目下的文件夹结构 这是用python命令生成的项目,在创建过程中默认生成多个平台的程序文件. 1.“resource”文件夹 该文件夹主要用于存放游戏中需要的图片.音频 ...
- MOOS学习笔记——多线程
/* * A simple example showing how to use a comms client */ #include "MOOS/libMOOS/Comms/MOOSAsy ...
- C++学习笔记(HelloWorld,类型和值)
现在有一个从控制台读取输入的小程序: #include "../std_lib_facilities.h" int main() { cout << "Ple ...
- Activiti学习笔记2 — HelloWorld
一. Maven的POM配置文件 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="htt ...
随机推荐
- Android简易实战教程--第十一话《获取手机所有应用信息Engine类详解》
如果想要获取系统手机应用的详细信息,那么下边代码可以直接作为模板使用.笔者对每一行代码都做了注解,供您参考.直接上代码: package com.example.itydl.engines; impo ...
- 最简单的基于librtmp的示例:接收(RTMP保存为FLV)
===================================================== 最简单的基于libRTMP的示例系列文章列表: 最简单的基于librtmp的示例:接收(RT ...
- 学习TensorFlow,浅析MNIST的python代码
在github上,tensorflow的star是22798,caffe是10006,torch是4500,theano是3661.作为小码农的我,最近一直在学习tensorflow,主要使用pyth ...
- Android回调事件传播-android学习之旅(四十五)
概念简介 代码演示 package peng.liu.test; import android.app.ActionBar; import android.app.Activity; import a ...
- iOS中 本地通知/本地通知详解 韩俊强的博客
布局如下:(重点讲本地通知) iOS开发者交流QQ群: 446310206 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 Notification是智能手机应用编 ...
- Mysql SQL Mode详解
Mysql SQL Mode简介 MySQL服务器能够工作在不同的SQL模式下,并能针对不同的客户端以不同的方式应用这些模式.这样,应用程序就能对服务器操作进行量身定制以满足自己的需求.这类模式定义了 ...
- 【Unity Shaders】Lighting Models —— 光照模型之Lit Sphere
本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源 ...
- A*寻路算法入门(二)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
- ROS(indigo)国外开源示例包括多机器人控制等基于V-Rep和Gazebo的仿真
ROS(indigo)国外开源示例包括多机器人的V-Rep和Gazebo仿真等 1 micros_swarm_framework 使用超级经典的stage. http://wiki.ros.org/m ...
- UNIX环境高级编程——死锁
操作系统中有若干进程并发执行,它们不断申请.使用.释放系统资源,虽然系统的进程协调.通信机制会对它们进行控制,但也可能出现若干进程都相互等待对方释放资源才能继续运行,否则就阻塞的情况.此时,若不借助外 ...