libxr  1.0
Want to be the best embedded framework
Loading...
Searching...
No Matches
LibXR::Topic::QueuedSubscriber Class Reference

构造函数,使用名称和无锁队列进行初始化 Constructor using a name and a lock-free queue More...

#include <message.hpp>

Public Member Functions

template<typename Data , uint32_t Length>
 QueuedSubscriber (const char *name, LockFreeQueue< Data > &queue, Domain *domain=nullptr)
 
template<typename Data >
 QueuedSubscriber (Topic topic, LockFreeQueue< Data > &queue)
 构造函数,使用 Topic 和无锁队列进行初始化 Constructor using a Topic and a lock-free queue
 
template<typename Data >
 QueuedSubscriber (const char *name, LockQueue< Data > &queue, Domain *domain=nullptr)
 构造函数,使用名称和带锁队列进行初始化 Constructor using a name and a locked queue
 
template<typename Data >
 QueuedSubscriber (Topic topic, LockQueue< Data > &queue)
 构造函数,使用 Topic 和带锁队列进行初始化 Constructor using a Topic and a locked queue
 

Detailed Description

构造函数,使用名称和无锁队列进行初始化 Constructor using a name and a lock-free queue

Template Parameters
Data队列存储的数据类型 Data type stored in the queue
Length队列长度 Queue length
Parameters
name订阅的主题名称 Name of the subscribed topic
queue订阅的数据队列 Subscribed data queue
domain可选的域指针 Optional domain pointer (default: nullptr)

Definition at line 353 of file message.hpp.

Constructor & Destructor Documentation

◆ QueuedSubscriber() [1/4]

template<typename Data , uint32_t Length>
LibXR::Topic::QueuedSubscriber::QueuedSubscriber ( const char * name,
LockFreeQueue< Data > & queue,
Domain * domain = nullptr )
inline

Definition at line 357 of file message.hpp.

359 {
360 *this = QueuedSubscriber(WaitTopic(name, UINT32_MAX, domain), queue);
361 }
static TopicHandle WaitTopic(const char *name, uint32_t timeout=UINT32_MAX, Domain *domain=nullptr)
等待主题的创建并返回其句柄 Waits for a topic to be created and returns its handle
Definition message.cpp:217

◆ QueuedSubscriber() [2/4]

template<typename Data >
LibXR::Topic::QueuedSubscriber::QueuedSubscriber ( Topic topic,
LockFreeQueue< Data > & queue )
inline

构造函数,使用 Topic 和无锁队列进行初始化 Constructor using a Topic and a lock-free queue

Template Parameters
Data队列存储的数据类型 Data type stored in the queue
Parameters
topic订阅的主题 Subscribed topic
queue订阅的数据队列 Subscribed data queue

Definition at line 371 of file message.hpp.

372 {
373 if (topic.block_->data_.check_length)
374 {
375 ASSERT(topic.block_->data_.max_length == sizeof(Data));
376 }
377 else
378 {
379 ASSERT(topic.block_->data_.max_length <= sizeof(Data));
380 }
381
382 auto block = new LockFreeList::Node<QueueBlock>;
383 block->data_.type = SuberType::QUEUE;
384 block->data_.queue = &queue;
385 block->data_.fun = [](RawData &data, void *arg, bool in_isr)
386 {
387 UNUSED(in_isr);
388 LockFreeQueue<Data> *queue = reinterpret_cast<LockFreeQueue<Data>>(arg);
389 queue->Push(reinterpret_cast<Data>(data.addr_));
390 };
391
392 topic.block_->data_.subers.Add(*block);
393 }
@ QUEUE
队列订阅者。Queued subscriber.

◆ QueuedSubscriber() [3/4]

template<typename Data >
LibXR::Topic::QueuedSubscriber::QueuedSubscriber ( const char * name,
LockQueue< Data > & queue,
Domain * domain = nullptr )
inline

构造函数,使用名称和带锁队列进行初始化 Constructor using a name and a locked queue

Template Parameters
Data队列存储的数据类型 Data type stored in the queue
Parameters
name订阅的主题名称 Name of the subscribed topic
queue订阅的数据队列 Subscribed data queue
domain可选的域指针 Optional domain pointer (default: nullptr)

Definition at line 404 of file message.hpp.

405 {
406 *this = QueuedSubscriber(WaitTopic(name, UINT32_MAX, domain), queue);
407 }

◆ QueuedSubscriber() [4/4]

template<typename Data >
LibXR::Topic::QueuedSubscriber::QueuedSubscriber ( Topic topic,
LockQueue< Data > & queue )
inline

构造函数,使用 Topic 和带锁队列进行初始化 Constructor using a Topic and a locked queue

Template Parameters
Data队列存储的数据类型 Data type stored in the queue
Parameters
topic订阅的主题 Subscribed topic
queue订阅的数据队列 Subscribed data queue

Definition at line 417 of file message.hpp.

418 {
419 if (topic.block_->data_.check_length)
420 {
421 ASSERT(topic.block_->data_.max_length == sizeof(Data));
422 }
423 else
424 {
425 ASSERT(topic.block_->data_.max_length <= sizeof(Data));
426 }
427
428 auto block = new LockFreeList::Node<QueueBlock>;
429 block->data_.type = SuberType::QUEUE;
430 block->data_.queue = &queue;
431 block->data_.fun = [](RawData &data, void *arg, bool in_isr)
432 {
433 LockQueue<Data> *queue = reinterpret_cast<LockQueue<Data> *>(arg);
434 queue->PushFromCallback(*reinterpret_cast<const Data *>(data.addr_), in_isr);
435 };
436
437 topic.block_->data_.subers.Add(*block);
438 }

The documentation for this class was generated from the following file: