.net LTS3.1升5.0和LTS6.0隐蔽的坑

  下面这段代码就是把ascll为0到127值 ,转成string,并判断在字符串中的位置,第5,6行代码分别用了两种IndexOf方法的重载。

for (var i = 0; i < 128; i++)
{
    var str1 = ((char)i).ToString();
    var str2 = $"---------------{str1}---------------";
    var no1 = str2.IndexOf(str1);
    var no2 = str2.IndexOf(str1, System.StringComparison.Ordinal);

    if (no1 != no2)
    {
        Console.ForegroundColor = ConsoleColor.Red;
        Console.WriteLine($"不等  i={i},str1={str1},no1={no1},no2={no2}");
    }
    else
    {
        Console.ForegroundColor = ConsoleColor.Green;
        Console.WriteLine($"相等  i={i},str1={str1},no1={no1},no2={no2}");
    }
    Console.ResetColor();
}

  结果如下,相等为绿色,不等为红色,并且在win10下的结果。

  .net core 3.1下的结果,一片绿光。

 

  .net 6.0下的结果,红色一片

 

  代码不动,为什么会出现这样的差异呢?

  这是因为在windows上,.net早期版本(.net core 1.0-3.1)是用NLS(国家语言支持或区域语言支持)来实现全球化的功能和字符串的一些处理功能,但在.net5.0后,windows 10 19年5月10日的更新中,带了icu.dll(ICU:Unicode国际组件)作为系统的一部分,所以就会出现上图红色部分,System.StringComparison.Ordinal参数,也是让字符串操作回归来的方式,方便适配原来的逻辑。

  这样一来5.0之后的版本就统一了各系统中的差异,让应用在切换系统部署时保持一致的运行逻辑。

  想要更快更方便的了解相关知识,可以关注微信公众号 
 

 

 

posted @ 2022-02-21 17:37  刘靖凯  阅读(86)  评论(0编辑  收藏  举报