0

1.用Where()方法进行筛选

using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1, 2, 3, 4, 5, 6, 7, 8, 89, 10 };
            //查询所有能被2整除的元素
            var query1 = intary.Where(num => num % 2 == 0);
            Console.WriteLine("Query1:");
            foreach (var item in query1)
            {
                Console.WriteLine("{0}", item);
            }

            //查询所有值大于3被索引的元素
            var query2 = intary.Where((num, index) => num > index * 3);
            Console.WriteLine("Query2:");
            foreach (var item in query2)
            {
                Console.WriteLine("{0}", item);
            }
        }
    }
}

2.用OrderBy()方法进行排序

using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1, 2, 3, 4, 5, 6, 7, 8, 89, 10 };
            //对所有元素按照%10进行升序排列,这是默认的排序方式
            var query1 = intary.OrderBy(val => val % 10 );
            Console.WriteLine("Query1:");
            foreach (var item in query1)
            {
                Console.WriteLine("{0}", item);
            }

            //对所有元素按照%10进行降序排列
            var query2 = intary.OrderByDescending(val => val % 10);
            Console.WriteLine("Query2:");
            foreach (var item in query2)
            {
                Console.WriteLine("{0}", item);
            }
        }
    }
}

以上的两个排序Demo都是采用默认的int排序比较器,在一些开发中,以下两种情况需要使用特定的数据比较器:

  • 默认的数据类型不能满足特殊的比较需要
  • 自定义的类不存在默认的数据比较器

using System;
using System.Linq;
using System.Collections.Generic;

namespace ConsoleApplication3
{
    //自定义int类型比较器,实现IComparable<int>接口
    class MyCompare : IComparer<int>
    {
        public int Compare(int x, int y)
        {
            int x1 = Math.Abs(x);
            int y1 = Math.Abs(y);
            if (x1 > y1)
            {
                return 1;
            }
            else if (x1 == y1)
            {
                return 0;
            }
            else
            {
                return -1;
            }
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            //实例化自定义比较器
            MyCompare mc = new MyCompare();
            int[] intary = { 1, -2, 3, -4, 5, -6, 7, -8, 9, -10 };
            var query1 = intary.OrderBy(val => val, mc);
            Console.WriteLine("Query1");
            foreach (var item in query1)
            {
                Console.WriteLine("{0}",item);
            }
        }
    }
}

3.用Skip()、SkipWhile()跳过元素

 using System;
using System.Linq;
using System.Collections.Generic;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40 };
            //跳过intAry中前3个元素
            var query1 = intary.Skip(3);
            Console.WriteLine("Query1");
            foreach (var item in query1)
            {
                Console.WriteLine("{0}", item);
            }

            //跳过intAry中小于5的元素
            var query2 = intary.SkipWhile(num => num < 5);
            Console.WriteLine("Query2");
            foreach (var item in query2)
            {
                Console.WriteLine("{0}", item);
            }
        }
    }
}


4.用Take()、TakeWhile()提取元素

using System;
using System.Linq;
using System.Collections.Generic;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40 };
            //取intAry中前3个元素
            var query1 = intary.Take(3);
            Console.WriteLine("Query1");
            foreach (var item in query1)
            {
                Console.WriteLine("{0}", item);
            }

            //取intAry中小于5的元素
            var query2 = intary.TakeWhile(num => num < 5);
            Console.WriteLine("Query2");
            foreach (var item in query2)
            {
                Console.WriteLine("{0}", item);
            }
        }
    }
}

5.对元素进行数值计算

  • Min():求最小值
  • Max():求最大值
  • Sum():求和
  • Average():求平均值

using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40 };
            var intMin = intary.Min();
            var intMax = intary.Max();
            var intSum = intary.Sum();
            var intAverage = intary.Average();
            Console.WriteLine("intary's min={0},max={1},sum={2},average={3}",intMin,intMax,intSum,intAverage);

            string[] strAry = { "Kevin", "James", "Ken", "Ben" };
            var strMin = strAry.Min();
            var strMax = strAry.Max();
            Console.WriteLine("strAry's Min = {0},Max={1}",strMin,strMax);
        }
    }
}

6.用Distinct()消除集合中相等的元素

 using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intary = { 1,1, 2,2, 3, 3, 4, 5};
            var query1 = intary.Distinct();
            foreach (var item in query1)
            {
                Console.WriteLine(item);
            }
        }
    }
}

7.用Concat()连接两个集合

using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            string[] strAry1 = {"Kevin","James","Ben"};
            string[] strAry2 = { "Ken","Joanna","cc"};
            var query1 = strAry1.Concat(strAry2);
            Console.WriteLine("Query1");
            foreach (var item in query1)
            {
                Console.WriteLine(item);
            }

            var query2 = strAry2.Concat(strAry1);
            Console.WriteLine("Query2");
            foreach (var item in query2)
            {
                Console.WriteLine(item);
            }
        }
    }
}

注意:Concat()方法是直接将两个集合中的元素连接在一起,不会进行重新排序、过滤等,就算两个集合中元素有重复也同样保留。

8.集合操作

说到集合,很容易想起并集、交集、差集3种常用操作。在LINQ中,IEnumerable<T>类分别通过Union()、Intersect()、Except完成这3种操作()。

using System;
using System.Linq;

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] intAry1 = {1,2,3};
            int[] intAry2 = {3,4,5};
            var query1 = intAry1.Union(intAry2);
            Console.WriteLine("并集");
            foreach (var item in query1)
            {
                Console.WriteLine(item);
            }

            var query2 = intAry1.Intersect(intAry2);
            Console.WriteLine("交集");
            foreach (var item in query2)
            {
                Console.WriteLine(item);
            }

http://www.cnblogs.com/wlb/archive/2009/08/26/1554026.html

关闭 返回顶部
联系我们
Copyright © 2011. 聚财吧. All rights reserved.