良许Linux教程网 干货合集 C# 减少嵌套循环具体方法

C# 减少嵌套循环具体方法

最近在解决性能优化的问题,看到了一堆嵌套循环,四五层级的循环真的有点过分了,在数据量成万,十万级别的时候,真的非常影响性能。本文介绍了C# 减少嵌套循环的两种方法,帮助各位选择适合自己的优化方案,优化程序性能

C# 减少嵌套循环具体方法

当然,除了关注明显的循环例如for、foreach,还应该关注隐晦一点的循环,例如datatable.select(),linq之类的list.where、list.find等。

要优化,排除业务问题,要考虑的就是代码技术了。看到循环查找数据,尽可能向Dictionary靠拢。

eg1:一个简单的key对应一条datarow

优化前:

using System.Linq;

namespace ConsoleApp1
{
   internal class Program
   {
       private static void Main(string[] args)
       {
           DataTable table = new DataTable();
           ...
           for (int i = 0; i  r["num"].ToString() == i.ToString());
               ...
           }
       }
   }
}

优化后:

using System.Data;
using System.Linq;

namespace ConsoleApp1
{
   internal class Program
   {
       private static void Main(string[] args)
       {
           DataTable table = new DataTable();
           ...
           var dict = table.AsEnumerable().ToDictionary(r => r["num"].ToString());
           for (int i = 0; i if (dict.ContainsKey(i.ToString()))
               {
                   var row = dict[i.ToString()];
               }
               ...
           }
       }      
   }
}

eg2:一个拼装的Key对应多条DataRow的字典

优化前:

using System.Data;
using System.Linq;

namespace ConsoleApp1
{
   internal class Program
   {
       private static void Main(string[] args)
       {
           DataTable table = new DataTable();  
           ...
           for (int i = 0; i "";
               ...
               var rows = table.AsEnumerable().Where(r => r["num"].ToString() == i.ToString() && r["name"].ToString() == name);
           }
       }            
   }
}

优化后:

using System.Data;
using System.Linq;

namespace ConsoleApp1
{
   internal class Program
   {
       private static void Main(string[] args)
       {
           DataTable table = new DataTable();
           var group = table.AsEnumerable().GroupBy(r => GetGroupKey(r["num"].ToString(), r["name"].ToString()));
           var dict= group.ToDictionary(r=>r.Key);
           ...
           for (int i = 0; i "";
               var key = GetGroupKey(i.ToString(), name);
               if (dict.ContainsKey(key))
               {
                   var rows = dict[key];
               }              
               ...
           }
       }      
       
       private static string GetGroupKey(string _num,string _name)
       {
           return $"num={_num}|name={_name}";
       }
   }
}

量变会引起质变。

以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !

137e00002230ad9f26e78-265x300
本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部