美图齐众专注资阳网站设计 资阳网站制作 资阳网站建设
资阳网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

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}";
       }
   }
}

量变会引起质变。


本文标题:C#减少嵌套循环具体方法
本文路径:http://www.zsjierui.cn/article/dhgsseo.html