温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++怎么实现双缓存队列

发布时间:2022-04-13 16:28:16 来源:亿速云 阅读:346 作者:iii 栏目:编程语言

这篇文章主要讲解了“C++怎么实现双缓存队列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++怎么实现双缓存队列”吧!

具体如下:

“双缓存队列”是我在一次开发任务中针对特殊场景设计出来的结构。使用场景为:发送端持续向接收端发送数据包——并且不理会接收端是否完成业务逻辑。由于接收端在任何情况下停止响应即可能产生数据丢失,因此无法简单的设计一条线程安全队列来对数据写入或读取(读取数据时将队列上锁视为对写入的停止响应)。

接收端首先向A队列中写入数据,然后当数据处理请求到来的时候切换到B队列继续写入,之后将A队列中的数据交给数据处理模块,处理完成以后A队列数据清空。当下一次数据处理请求到来时,再将写入请求切换回A队列,并把B队列中的数据提交给数据处理模块再清空队列B,轮流作业。

有了思路以后,代码就比较简单了。

#include <list> template<typename T> class DoubleArray {   struct NODE {     T t;     NODE* next;   };   int size_a;   int size_b;   NODE* header_a;   NODE* header_a_cur;   NODE* header_b;   NODE* header_b_cur;   int trigger; public:   DoubleArray() : size_a(0), size_b(0), trigger(0), header_a(0), header_a_cur(0), header_b(0), header_b_cur(0) {   }   int push(T t);   std::list<T>& fetch(std::list<T>& list); }; template<typename T> int DoubleArray<T>::push(T t) {   NODE *n = new NODE;   n->t = t;   n->next = 0;   if (size_a == 0 && trigger == 0) {     header_a = n;     header_a_cur = n;     size_a++;   } else if (size_b == 0 && trigger == 1) {     header_b = n;     header_b_cur = n;     size_b++;   } else {     switch (trigger) {       case 0:         header_a_cur->next = n;         header_a_cur = n;         size_a++;         break;       case 1:         header_b_cur->next = n;         header_b_cur = n;         size_b++;         break;     }   } } template<typename T> std::list<T>& DoubleArray<T>::fetch(std::list<T>& list) {   switch (trigger) {     case 0:       if (header_a != 0) {         // change b         trigger = 1;         // fetch a         NODE* temp = header_a;         while (temp) {           list.push_back(temp->t);           temp = temp->next;         }         // delete a         temp = header_a;         for (int i = 0; i < size_a; ++i) {           NODE* p = temp;           temp = temp->next;           delete p;         }         size_a = 0;         header_a = 0;         header_a_cur = 0;       }       break;     case 1:       if (header_b != 0) {         // change a         trigger = 0;         // fetch b         NODE* temp = header_b;         // delete b         while (temp) {           list.push_back(temp->t);           temp = temp->next;         }         temp = header_b;         for (int i = 0; i < size_b; ++i) {           NODE* p = temp;           temp = temp->next;           delete p;         }         size_b = 0;         header_b = 0;         header_b_cur = 0;       }       break;   }   return list; }

注:开发环境与IDE分别为CentOS 7,NetBeans 8.2

感谢各位的阅读,以上就是“C++怎么实现双缓存队列”的内容了,经过本文的学习后,相信大家对C++怎么实现双缓存队列这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI