当前位置: 首页 > news >正文

github源码指引:共享内存、数据结构与算法:树形结构ListTree

初级代码游戏的专栏介绍与文章目录-CSDN博客

我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。

这些代码大部分以Linux为目标但部分代码是纯C++的,可以在任何平台上使用。


        专题:共享内存、数据结构与算法_初级代码游戏的博客-CSDN博客

        本文讲解带有子项的链表。

一、介绍

        与上一篇介绍的单向链表相比,多了一个子项指针。可以理解为原来的链表是兄弟关系,子项指针则是父子关系,从而可以构建树形结构。

        节点结构如下:

		T_SHM_SIZE hNext;//-1:无;0-N,指向下个地址T_SHM_SIZE hChild;//-1:无;0-N,指向子数据T_DATA data;

        迭代器复杂一些:

			bool isEnd()const { return -1 == handle; }bool hasNext()const { return -1 != LIST_NODE::at(handle).hNext; }long getNext()const { return LIST_NODE::at(handle).hNext; }void setNext(T_SHM_SIZE h)const { LIST_NODE::at(handle).hNext = h; }void setChild(T_SHM_SIZE h)const { LIST_NODE::at(handle).hChild = h; }long getChild()const { return LIST_NODE::at(handle).hChild; }

        容器操作也复杂一些:

		//查找一个项,没找到返回false,h返回找到的位置或列表最后一个节点bool FindInList(iterator const & head, T_DATA const & data, iterator & it)const;//添加data到head,如果head是isEnd则添加到新列表并放置位置在h,如果已经存在则覆盖,如果head是isEnd则会被修改bool AddList(iterator & head, T_DATA const & data, iterator & it);//添加data到head,如果head是isEnd则添加到新列表并放置位置在h,如果已经存在则覆盖,如果head是isEnd则会被修改bool AddChild(iterator const & node, T_DATA const & data, iterator & it);//添加data到head的尾部,如果head是isEnd则添加到新列表并放置位置在head,不检查是否存在bool AddTail(iterator & head,T_DATA const & data);//删除子项bool DeleteChild(iterator const & node);//删除链表bool DeleteList(iterator const & head);//删除链表的一个项bool DeleteListOne(iterator & head,iterator const & toDelete);

二、演示代码

#include "shmMultiListTree.h"
class CTest_T_MULTI_LISTTREE
{
public:struct DemoData : public CActiveObjectBase{typedef DemoData T_ME;long a = 0;long b = 0;long c = 0;sstring<8> s;//用于需要排序的场合bool operator < (T_ME const& tmp)const{return a == tmp.a ? (b == tmp.b ? c < tmp.c : b < tmp.b) : a < tmp.a;}//部分比较函数static bool Less_A(T_ME const& tmp1, T_ME const& tmp2){return tmp1.a < tmp2.a;}//某些场合也需要等于bool operator == (T_ME const& tmp)const { return !(*this < tmp) && !(tmp < *this); }friend ostream& operator << (ostream& o, T_ME const& d){return o << d.a << " " << d.b << " " << d.c << " " << d.s.c_str();}//关键字的hash值,用于分块场合,应保证hash值的最后一部分仍然是平均分布的long keyhash()const { return a; }//用于输出数据的场合string& toString(string& str)const{char buf[2048];sprintf(buf, "%ld %ld %ld %s", a, b, c, s.c_str());return str = buf;}//用于表格输出static bool AddTableColumns(CHtmlDoc::CHtmlTable2& table){table.AddCol("A", CHtmlDoc::CHtmlDoc_DATACLASS_RIGHT);table.AddCol("B", CHtmlDoc::CHtmlDoc_DATACLASS_RIGHT);table.AddCol("C", CHtmlDoc::CHtmlDoc_DATACLASS_RIGHT);table.AddCol("S", CHtmlDoc::CHtmlDoc_DATACLASS_RIGHT);return true;}bool AddTableData(CHtmlDoc::CHtmlTable2& table)const{table.AddData(a);table.AddData(b);table.AddData(c);table.AddData(s.c_str());return true;}};typedef T_MULTI_LISTTREE<DemoData, PI_TEST_1 > T_CONTINER;static int test_T_MULTI_LISTTREE(int argc, char** argv){T_CONTINER a("test", 1);a.getIShmActiveObject()->DestoryShm();if (!a.getIShmActiveObject()->CreateShm())return __LINE__;thelog << endi;if (!a.getIShmActiveObject()->Attach(false))return __LINE__;thelog << endi;string str;vector<T_CONTINER::iterator > v_heads;for (int i = 0; i < 2; ++i){T_CONTINER::iterator head;for (int j = 10; j < 12; ++j){DemoData tmp2;tmp2.a = i;tmp2.b = j;T_CONTINER::iterator it2;if (!a.AddList(head, tmp2, it2))return __LINE__;thelog << "添加成功 " << head.handle << " " << it2.handle << " : " << tmp2.toString(str) << endi;if(10==j)v_heads.push_back(head);for (int k = 100; k < 102; ++k){DemoData tmp3;tmp3.a = i;tmp3.b = j;tmp3.c = k;T_CONTINER::iterator it_child;if (!a.AddChild(it2, tmp3, it_child))return __LINE__;thelog << "添加成功 " << i << " " << j << " " << k << " : " << tmp3.toString(str) << endi;}}}for (vector<T_CONTINER::iterator >::const_iterator it = v_heads.begin(); it != v_heads.end(); ++it){str = "";thelog << (*it).handle << endl << a.ReportList((*it).handle, str) << endi;}a.getIShmActiveObject()->RunCmdUI();return 0;}
};

        这段代码构建了两个链表,每个链表有两个节点,每个节点有两个子数据。

三、运行结果

        rebuild.sh 编译,run.sh运行,命令26(初次运行要先创建主共享内存命令0-1):

[09-04 08:52:44][应用][信息][shmfctest2.h            : 583(test_T_MULTI_LISTTREE)][  0.00]00:0 10 01:0 10 1002:0 10 1013:0 11 04:0 11 1005:0 11 101[09-04 08:52:44][应用][信息][shmfctest2.h            : 583(test_T_MULTI_LISTTREE)][  0.00]66:1 10 07:1 10 1008:1 10 1019:1 11 010:1 11 10011:1 11 101

         冒号前面是节点号。使用共享内存管理界面的命令9可以查看到具体结构:

 h NEXT CHILD | A  B   C S
-- ---- ----- - - -- --- -0    3     1 | 0 10   01    2    -1 | 0 10 1002   -1    -1 | 0 10 1013   -1     4 | 0 11   04    5    -1 | 0 11 1005   -1    -1 | 0 11 1016    9     7 | 1 10   07    8    -1 | 1 10 1008   -1    -1 | 1 10 1019   -1    10 | 1 11   0
10   11    -1 | 1 11 100
11   -1    -1 | 1 11 101
-- ---- ----- - - -- --- -

        应该很容易看明白了。


(这里是文档结束)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 菜单权限功能设计
  • 算法_队列+宽度优先搜索---持续更新
  • 数据库C语言删除修改和输出
  • 6. LinkedList与链表
  • LLM大模型学习:AI大模型原理、应用与未来趋势!
  • 大模型实战一、Ollama+RagFlow 部署本地知识库
  • yolov5 +gui界面+单目测距 实现对图片视频摄像头的测距
  • 屏幕空间UV 警戒线
  • 氚云,低代码领风者如何破解行业的“中式焦虑”?
  • 首个大模型供应链安全领域的国际标准,WDTA《大模型供应链安全要求》标准解读
  • 【复盘】近期博客内容升级
  • [Linux]:文件(下)
  • 网络编程9.10
  • 爆改YOLOv8|利用yolov9的ADown改进卷积Conv-轻量化
  • 速盾:高防 cdn 分布式防御攻击?
  • ➹使用webpack配置多页面应用(MPA)
  • Java 多线程编程之:notify 和 wait 用法
  • JavaScript 一些 DOM 的知识点
  • maya建模与骨骼动画快速实现人工鱼
  • MySQL主从复制读写分离及奇怪的问题
  • QQ浏览器x5内核的兼容性问题
  • Vue学习第二天
  • 记录一下第一次使用npm
  • 讲清楚之javascript作用域
  • 前嗅ForeSpider中数据浏览界面介绍
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 我的面试准备过程--容器(更新中)
  • 小程序滚动组件,左边导航栏与右边内容联动效果实现
  • 一文看透浏览器架构
  • Oracle Portal 11g Diagnostics using Remote Diagnostic Agent (RDA) [ID 1059805.
  • LIGO、Virgo第三轮探测告捷,同时探测到一对黑洞合并产生的引力波事件 ...
  • PostgreSQL之连接数修改
  • 智能情侣枕Pillow Talk,倾听彼此的心跳
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​第20课 在Android Native开发中加入新的C++类
  • ​七周四次课(5月9日)iptables filter表案例、iptables nat表应用
  • # Spring Cloud Alibaba Nacos_配置中心与服务发现(四)
  • #include
  • #Linux(权限管理)
  • #QT(智能家居界面-界面切换)
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • (14)Hive调优——合并小文件
  • (C++)栈的链式存储结构(出栈、入栈、判空、遍历、销毁)(数据结构与算法)
  • (补)B+树一些思想
  • (附源码)ssm经济信息门户网站 毕业设计 141634
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (欧拉)openEuler系统添加网卡文件配置流程、(欧拉)openEuler系统手动配置ipv6地址流程、(欧拉)openEuler系统网络管理说明
  • (篇九)MySQL常用内置函数
  • (五)网络优化与超参数选择--九五小庞
  • (一)WLAN定义和基本架构转
  • (转)大道至简,职场上做人做事做管理
  • (转)平衡树
  • . ./ bash dash source 这五种执行shell脚本方式 区别
  • .gitignore文件—git忽略文件
  • .htaccess 强制https 单独排除某个目录