Linq 查询结果 可能遵循 2 º,2¹,2 ²,......增长计算

        static void Main(string[] args)
        {
            int[] array = new int[] { 102, 12, 23, 412, 22, 14, 45, 65, 33 };

            var obj = from item in array
                      orderby item ascending
                      group item by item / 100;
            
  
            foreach (var item in obj)
            {
                Console.WriteLine(item.ToString());
            }


            return;
        }  

无聊随便写Linq玩,突然发现这个问题,请看上面这段代码,理想状态下,obj结果应该是:

{0:[12,14,22,23,33,45,65]        

1:[102]

4:[412]}

实际结果(请用监视查看,最后多出的0打印不出来的):

{0:[12,14,22,23,33,45,65,0]                 //看好 8位 = 23 ,不足补0

1:[102]         //20

4:[412]}        //20

也就是说0分组最后多个0,但是这个0不在原数组array中定义,它是怎么出现的?

后来修改数组int[] array = new int[] { 102, 12, 23, 412, 22,111,156, 14, 45, 65, 33,88 };

        public static void Main(string[] args)
        {
            int[] array = new int[] { 102, 12, 23, 412, 22,111,156, 14, 45, 65, 33,88 };

            var obj = from item in array
                      orderby item ascending
                      group item by item / 100;
            
            foreach (var item in obj)
            {
                foreach (var t in item)
                {
                    Console.Write(t + "	");
                }
                Console.WriteLine();
            }
            
            return;
        }    

这次测试结果是(请用监视查看,1分组末尾多个0打印不出来的):

{0:[12,14,22,23,33,45,65,88]         // 8位 = 23 

1:[102,111,156,0]    // 4位 = 22,不足补0

4:[412]}        //20

于是,猜测 Linq 查询结果 可能遵循 2 º,2¹,2 ²,......增长计算

原文地址:https://www.cnblogs.com/preacher/p/3942117.html