DDS笔记: hello world解析

fast dds 2.2.x中hello world代码总结:

1) 核心逻辑流程

获取DomainParticipantFactory -> 创建participant -> 注册sub-pub type -> 创建topic(顺序可延后) -> 创建publisher / subscriber -> 创建writer / reader -> write / read / WaitSet.wait

2)除获取factory外,创建其他对象之前都要准备好对应qos、listener、mask等参数。

3)subscriber有2种模式:

(1)listener callback

创建subscriber时传入listener参数,通过listener回调事件和数据(on_subscription_matched, on_data_available)。

(2)wait set

创建subscriber后,通过WaitSet来关联多个Condition,监听相应各个Condition的变化。

关联reader的status condition,监听topic的订阅和数据更新

关联stop condition,监听程序停止动作。

  1. publisher app主要流程
    1)创建factory
    2)创建participant
    3)创建publisher
    4)创建topic
    5)创建writer
    6)发布数据
c++ 复制代码
	// 1
	auto factory = DomainParticipantFactory::get_instance();
	// 2 listener null, mask none
	auto participant = factory->create_participant_with_default_profile(null_listener, mask);
	assert(participant);
	// 注册关联pub-sub-type
	pub_sub_type.register_type(participant);

	// 3 listener null, mask none
	auto publisher = pariticipant->create_publisher(pub_qos, null_listener, mask);
	assert(publisher);

	// 4
	auto topic = participant->create_topic(topic_name, topic_type, topic_qos);
	assert(topic);
	
	// 5 listener, mask all
	auto writer = publisher->create_datawriter(topic, writer_qos, listener, mask);
	assert(writer);

	// 6
	Helloworld hello{...};
	writer->write(&hello);
  1. ListenerSubscriberApp主要流程
    1)创建participant factory
    2)创建participant
    3)创建subscriber
    4)创建topic
    5)创建data reader
    6)data callback
cpp 复制代码
	// 1
	auto factory = DomainParticipantFactory::get_instance();

	// 2 listener null, mask none
	auto participant = factory->create_participant_with_default_profile(null_listener, mask);
	assert(participant);
	pub_sub_type.register_type(participant);

	// 3 listener null, mask none
	auto subscriber = participant->create_subscriber(sub_qos, null_listener, mask);
	assert(subscriber);

	// 4
	auto topic = participant->create_topic(topic_name, topic_type, topic_qos);
	assert(topic);

	// 5 listener, mask all
	auto reader = subscriber->create_datareader(topic, reader_qos, listener, mask);
	assert(reader);

	// 6 data callback
	class DataReaderListener {
		void on_data_available(DataReader *reader); // <<<---
		void on_subscription_matched(DataReader *reader, status); // <<<---
		void on_requested_deadline_missed(DataReader *reader, status);
		void on_liveness_changed(DataReader *reader, status);
		void on_sample_rejected(DataReader *reader, status);
		void on_sample_lost(DataReader *reader, status);
		void on_requested_incompatible_qos(DataReader *reader, status);
	};
	
	void on_subscription_matched(DataReader *reader, SubscriptionMatchedStatus& status) {
		// check matched count
	}

	void on_data_available(Datareader *reader) {
		// read and process data
		Helloworld hello;
		SampleInfo info;
		reader->take_next_sample(&hello, &info);
	}
  1. WaitsetSubscriberApp main process
    1)创建factory
    2)创建participant
    3)创建subscriber
    4)创建topic
    5)创建data reader
    6)WaitSet attach Condition
    7)WaitSet wait Condition
cpp 复制代码
	// 1
	auto factory = DomainParticipantFactory::get_instance();
	
	// 2 listener null, mask none
	auto participant = factory->create_participant_with_default_profile(null_listener, mask);
	assert(participant);	
	pub_sub_type.register_type(participant);

	// 3 listener null, mask none
	auto subscriber = participant->create_subscriber(sub_qos, null_listener, mask)
	assert(subscriber);
	
	// 4
	auto topic = participant->create_topic(topic_name, topic_type, topic_qos);
	assert(topic);

	// 5 null listener, mask all
	auto reader = subscriber->create_datareader(topic, sub_qos, null_listener, mask);
	assert(reader);

	// 6
//	.hpp: 	WaitSet wait_setp;
//			GuardCondtion terminate_condition;

	// ---->>> ***************
	// 这里是关键,把wait和reader的status condition关联起来,监听reader的变化
	// 同时处理terminate_condition,监听stop事件
	wait_set.attach_condition(reader->get_statuscondition());
	wait_set.attach_condition(terminate_condition);

	// 7
	ConditionSeq triggered_conditions;
	wait_set.wait(triggered_conditions, timeout);
	for(Condition* cond : triggered_conditions) {
		auto *status_cond = dynamic_cast<StatusCondition>(cond);
		assert(status_cond);

		Entity *entity = status_cond.get_entity();
		StatusMask changed_status = entity->get_status_changes();

		if (changed_status.is_active(StatusMask::subscriptioin_matched()) {
			// check matched count
		}

		if (changed_status.is_active(StatusMask::data_available())) {
			// read and process data
			SampleInfo info;
			Helloworld hello;
			reader->take_next_sample(&hello, &info);
		}
	}
相关推荐
烦躁的大鼻嘎18 分钟前
【Linux】ELF与动静态库的“暗黑兵法”:程序是如何跑起来的?
linux·运维·服务器·c++·vscode·ubuntu
ShineSpark32 分钟前
C++面试2——C与C++的关系
c语言·c++·面试
卓律涤40 分钟前
【找工作系列①】【大四毕业】【复习】巩固JavaScript,了解ES6。
开发语言·前端·javascript·笔记·程序人生·职场和发展·es6
无聊的小坏坏1 小时前
【C++】set、map 容器的使用
c++·stl
※※冰馨※※1 小时前
彻底解决QT5 中文编译不过问题
c++·windows·qt
扶尔魔ocy1 小时前
QT使用QXlsx读取excel表格中的图片
c++·excel
love530love1 小时前
【笔记】记一次PyCharm的问题反馈
ide·人工智能·windows·笔记·python·pycharm
Ronin3051 小时前
【C++】18.二叉搜索树
开发语言·数据结构·c++
Susea&1 小时前
初始C++:类和对象(中)
c语言·开发语言·c++
笑鸿的学习笔记2 小时前
虚幻引擎5-Unreal Engine笔记之Pawn与胶囊体的关系
笔记·ue5·虚幻