C#中可为NULL的运算符怎么用

这篇文章主要介绍了C#中可为NULL的运算符怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

成都一家集口碑和实力的网站建设服务商,拥有专业的企业建站团队和靠谱的建站技术,十载企业及个人网站建设经验 ,为成都成百上千家客户提供网页设计制作,网站开发,企业网站制作建设等服务,包括成都营销型网站建设,高端网站设计,同时也为不同行业的客户提供网站建设、网站制作的服务,包括成都电商型网站制作建设,装修行业网站制作建设,传统机械行业网站建设,传统农业行业网站制作建设。在成都做网站,选网站制作建设服务商就选创新互联建站

?.和?[]

null条件运算符在C#6以后可用,仅当操作数为非null时才会访问成员或者访问元素。?.和?[]很好区分;我们知道'.'是访问成员或者命空间啥的,'[]' 索引器访问,以下演示运算符的用法:

 static double? SumNumbers(List setsOfNumbers, int indexOfSetToSum)
       {
           //如果 setsOfNumbers 非空,访问指定的索引;如果对应元素的索引不为空,求和
           return setsOfNumbers?[indexOfSetToSum]?.Sum() ;
       }
       
 var sum1 = SumNumbers(null, 0);
           Console.WriteLine(sum1??Double.NaN);  // 输出: NaN

           var numberSets = new List { new[] { 1.0, 2.0, 3.0 }, null };

           var sum2 = SumNumbers(numberSets, 0);
           Console.WriteLine(sum2 ?? Double.NaN);  // 输出: 6

           var sum3 = SumNumbers(numberSets, 1);
           Console.WriteLine(sum3 ?? Double.NaN);  // 输出: NaN

??

NUll 合并运算符,什么意思?就是如果这个值为空,就使用另外一个值, a??b,如果a为非null,则结果为a;否则结果为b。仅当a为null时,操作才计算b。常用场景比如:使用throw表达式作为??运算符的右操作数,检测数据、当获取为空时赋值默认值等等。

var comment = _blogService.GetBlogCommentById(id)
               ?? throw new ArgumentException("指定的id为查到对应数据!", nameof(id));

??=

运算符 ??= 是在C#8.0引入的 null 合并赋值运算符。什么意思?就是当左操作数计算为null时,才能使用运算符??= 将其有操作符的值 赋值给左操作数。实例代码如下:

List numbers = null;
           int? i = null;

           numbers ??= new List();
           numbers.Add(i ??= 66);
           numbers.Add(i ??= 99);

           //等价于一下代码
           //if (i==null)
           //{
           //    i = 66;
           //    numbers.Add(i.Value);
           //}

           //if (i == null)
           //{
           //    i = 99;
           //}
           //numbers.Add(i.Value);


           Console.WriteLine(string.Join(" ", numbers));  // 输出: 66 66
           Console.WriteLine(i);  // output: 66

感谢你能够认真阅读完这篇文章,希望小编分享的“C#中可为NULL的运算符怎么用”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!


名称栏目:C#中可为NULL的运算符怎么用
网页路径:http://hbruida.cn/article/gdddod.html