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

递归应用判断是否循环引用

var data = await _IDBInstance.DBOperation.QueryAsync<FormulaReference>(sql);//向上查询引用公式  List<FormulaReference> GetSonNode(long id, List<FormulaReference> nodeList, List<long> path = null){if (path == null){path = new List<long>();}if (path.Contains(id)){var formulaReferences = nodeList.Where(x => x.RefFormulaRecId == id);_logger.Error("出现循环引用:" + id + "_数据:" + JsonConvert.SerializeObject(formulaReferences), null);// 出现循环引用,抛出异常或返回空列表等return new List<FormulaReference>();}path.Add(id);var query = nodeList.Where(c => c.RefFormulaRecId == id);var result = query.Concat(query.SelectMany(t => GetSonNode(t.FormulaRecId, nodeList, path))).ToList();path.Remove(id);return result;}var result = new List<FormulaReference>();foreach (var item in formulaRecIdList){result.AddRange(GetSonNode(item, data.ToList()));}

代码中通过判断 path 列表是否包含当前的 id 来判断是否出现循环引用。如果 path 中已经包含了当前的 id,则表示在查询过程中出现了循环引用,会记录错误日志,并返回一个空的 FormulaReference 列表作为结果。这样可以避免在循环引用的情况下出现无限递归的情况,并及时处理循环引用的问题。

http://www.lryc.cn/news/153123.html

相关文章:

  • 使用nginx-lua配置统一url自动跳转到hadoop-ha集群的active节点
  • AJAX学习笔记2发送Post请求
  • 产品团队的需求分析指南
  • Python算法——排序算法(冒泡、选择、插入、快速、堆排序、并归排序、希尔、计数、桶排序、基数排序)
  • [Linux]文件描述符(万字详解)
  • RenderTarget导出成图片,CineCamera相机
  • 深入探讨Java虚拟机(JVM):执行流程、内存管理和垃圾回收机制
  • 3D 碰撞检测
  • Unity Canvas动画不显示的问题
  • NSSCTF2nd与羊城杯部分记录
  • 数据库(一) 基础知识
  • vue从零开始学习
  • dji uav建图导航系列(三)模拟建图、导航
  • PixelSNAIL论文代码学习(1)——总体框架和平移实现因果卷积
  • Python大数据处理利器之Pyspark详解
  • S905L3A(M401A)拆解, 运行EmuELEC和Armbian
  • stack和queue容器
  • 面向对象基础
  • spring集成mybatis
  • 抽象轻松c语言
  • Redis布隆过滤器原理
  • 写代码时候的命名规则、命名规范、命名常用词汇
  • Linux之iptables防火墙
  • 启动服务报错:Command line is too long Shorten command line for xxx or also for Spri
  • docker安装elasticsearch、kibana
  • 前端 CSS - 如何隐藏右侧的滚动条 -关于出现过多的滚动条导致界面不美观
  • 2.神经网络的实现
  • 合宙Air724UG LuatOS-Air LVGL API控件-键盘 (Keyboard)
  • pytorch深度学习实践
  • 直方图反向投影(Histogram Backprojection)