C#之Linq、where()、FindAll()的区别

2021-07-09 07:11

阅读:659

原地址

C#之Linq、where()、FindAll()的区别

对于实现了IEnumerable接口的类、类型、集合可以使用Linq、Linq的扩展方法where()、FindAll()来查询符合谓词约束的数据。这三者之间执行的方式是不一样的,同样的数据同样的查询条件返回的结果也不相同。先上代码再分析。


            public static void LaterSelect()       
             {   
                     var names = new List { "Nino", "Alberto", "Juan", "Mike", "Phil" 
             }; 
            
             var namesWithJ = from n in names            
                             where n.StartsWith("J")       
                              orderby n     
                               select n;   

            var namesWithJforWhere = names.Where(n => n.StartsWith("J")); 
            var namesWithJforFindAll = names.FindAll(n => n.StartsWith("J"));  
             
            Console.WriteLine("First iteration by Linq:");
            
                      
            foreach (string name in namesWithJ)            
            {               
             Console.WriteLine(name);                 
            }         
             Console.WriteLine("First iteration by names.Where():");      
            
             foreach (var name in namesWithJforWhere)      
             {               
             Console.WriteLine(name);  
              }        
            
              Console.WriteLine("First iteration by names.FindAll():");
                    
              foreach (var name in namesWithJforFindAll)          
              {          
                  Console.WriteLine(name);           
              }       
             
              Console.WriteLine();   
              
              names.Add("John");  
              names.Add("Jim");
               names.Add("Jack"); 
               names.Add("Denny"); 
               Console.WriteLine("Second iteration by Linq:");     
                foreach (string name in namesWithJ)        
                {              
                 Console.WriteLine(name);    
                } 
            
                     
              Console.WriteLine("Second iteration by names.Where():");  
             
                 foreach (var name in namesWithJforWhere)          
                {         
                   Console.WriteLine(name);    
                }            
                   Console.WriteLine("Second iteration by names.FindAll():");     
                   foreach (var name in namesWithJforFindAll)         
                {        
                    Console.WriteLine(name);     
                }     
               }
          
            

输出结果:

技术分享图片技术分享图片

分析

      从输出结果可以看出,Linq和where两种方式的结果是相同的,说明这两者之间没有区别,当定义一个查询后并没有立即执行查询而是在执行foreach循环的时候才执行查询而且是在每一次执行foreach循环的时候去执行查询,这样只要数据是变化的结果就会是变化的。但是在一些情况下,这是不可行的。调用扩展方法 ToArray()、ToEnumerable()、ToList()等可以改变这个操作,使返回的结果始终一致,这里是在调用To*这些方法时执行了一次查询而且不是延迟查询。FindAll()方法和Linq、where是有区别的,FindAll()不是延迟加载或者说延迟查询,当定义一个查询后就立即查询出所有符合条件的数据保存在变量中。


评论


亲,登录后才可以留言!