linq读书笔记2-查询内存中的对象

上次我们说到了linq对数组内容的检索,自.net2.0以后,泛型成了很常见的一种应用技术,linq对泛型的检索也提供了完善的支持

如对list类型的支持,范例如下:

    class Program
    {
        static void Main(string[] args)
        {
            List<Books> samplebooks = new List<Books>() {
                                                   new Books{Id=1,Name="book1"},
                                                   new Books{Id=2,Name="book2"},
                                                   new Books{Id=3,Name="book3"}
                                                };
            var book = samplebooks.Where(p => p.Name.Contains("2"))
                          .Select(p=>p.Name);
            foreach (var item in book)
            {
                Console.WriteLine(item);
            }
                            
            Console.Read();
            
        }
    }
    class Books
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }

以上的例子只是我们很常见的一个场景,那么linq是不是支持我们.net中的所有类型呢,事实上linq支持所有实现了IEnumable<T>接口的集合,.net中的大部分集合都实现了该接口,但是并不是所有的集合都实现 了该接口事实上只有支持强类型胡集合才实现了该接口,如数组,list,字典等,都是强类型的,所以我们可以对这些对象应用linq to object技术。

对于非泛型的集合,如arrarlist,dataset等集合并没有实现IEnumable<T>接口但是却实现了IEnumabler接口,这样的话是不是不能应泛型技术呢,当然这也还是有办法去处理 的,我们后面会提到。

下面我们看一些linq的基本的操作:

where操作:

功能:条件过滤

操作符声明:

public static IEnumerable<T> where<T>{

  this IEnumerable<T> source,

      Func<T,bool> predicate

}

predicate的第一个元素表明了将参与判断的元素,若该元素判断通过将返回为true,否则返回false

通过对source的观察我们也可以发现,where实质为一扩展方法,这个通过this关键字已经很明显的暴露了出来。而predicate的实现实质则是通过委托来做处理,通过对参数predicate的观察也可以很明显的反应出来.

同时where还提供了一个重载的版本:

public static IEnumerable<T> where<T>{

  this IEnumerable<T> source,

     Func<T,int,bool> predicate

}

predicate的第二个参数表示当前元素在源序列中的索引位置(以0为开始)

以下为该重载的一个范例代码:

IEnumerable<Books> book=samplebooks.where(book,index)=>((book.Name.Contains("2") )&&( (index&1)==1));

以上代码即为找出名称中包含2且在序列中奇数位置的图书

 

 

 

你可能感兴趣的:(LINQ)