星空网 > 软件开发 > ASP.net

C# 的OrderBy()函数的排序问题

昨天在客户现场遇到一个很奇葩的问题,猜下下面代码的排序输出是什么:

static void Main(){  List<string> strs = new List<string>(){"11", "12", "1:"};  foreach(string str in strs.OrderBy(n => n))    Console.writeLine(str);}

是这个么:

11121:

No, No, No。实际输出了这个:

1:1112

为什么?冒号的ASCII码值不是在0~9的后面么?我也没搞懂为什么C#的默认Sorter是按照这个顺序排序的。好在OrderBy()函数支持自定义Sorter,像下面一样修改下就行了。

static void Main(){  OrdinalComparer comp = new OrdinalComparer();  List<string> strs = new List<string>(){"11", "12", "1:"};  foreach(string str in strs.OrderBy(n => n, comp))    Console.writeLine(str);}public class OrdinalComparer: System.Collections.Generic.IComparer<String>{  public int Compare(String x, String y)  {    return string.CompareOrdinal(x, y);  } }

不过还是不知道为什么OrderBy的默认排序要设置成这样,Python2.3的默认排序就是按ASCII码排的。这导致我和别人写了同一个算法,结果python和C#排序输出结果不一致。哪位熟悉CLR的博友可以告诉我原因么?




原标题:C# 的OrderBy()函数的排序问题

关键词:C#

C#
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流