C#中包含?的运算符使用汇总

总目录



前言

本文将含有?运算符的各种使用进行汇总,方便系统性记忆和知识回顾。


一、使用概述

用法描述
?可空类型修饰符
?:三目运算符
??空合并运算符
??=??=运算符
?.Null检查运算符
?[]?[]运算符

二、使用说明

1.可空类型修饰符

正常情况下我们可以将引用类型赋值为null,但是不可以将值类型赋值为null。

代码如下(示例):

string str = null;//可以
int inum = null;//不可以,编译器报错

但是如果我们使用?可空类型修饰符,则可以实现如下效果:

string str = null;//可以
int? inum = null;//可以,编译器不会报错

用可空类型修饰符 ? 来修饰,则值类型也可为空。
T? 其实是 System.Nullable(泛型结构)的缩写形式,也就意味着当你用到 T?时编译器编译时会把T?编译成 System.Nullable 的形式。

例如:int? 编译后便是 System.Nullable 的形式。

2.三目运算符

x?y:z 表示如果表达式 x 为 true,则返回 y;如果 x 为 false,则返回 z,是 if{}else{} 的简单形式。

代码如下(示例):

        static void Main(string[] args)
        {
            int a=11; 
            int b=22;
            int c = a > b ? a : b;
            Console.WriteLine($"c={c}");
            Console.ReadLine();//结果: c=22
        }

3.空合并运算符

用于定义可空类型和引用类型的默认值。
如果此运算符的左操作数不为 null,则此运算符将返回左操作数,否则返回右操作数。

例如:a??b 当 a 为 null 时则返回 b,a 不为 null 时则返回 a 本身。

空合并运算符为右结合运算符,即操作时从右向左进行组合的。

如: a??b??c 的形式按 a??(b??c) 计算。

代码如下(示例):

        static void Main(string[] args)
        {
            string aStr = "aStr";
            string bStr = null;
            string cStr = aStr ?? bStr;
            string dStr = bStr ?? aStr;
            Console.WriteLine($"cStr={cStr},dStr={dStr}");
            Console.ReadLine();//结果   cStr=aStr,dStr=aStr
			//?? 更多还是用于一些类或者对象的默认值定义
        }

另外?? 可以理解为三元运算符的简化形式:

string cStr = aStr ?? bStr;
//效果等同于
string cStr = (aStr==null) ? bStr:aStr;

4.??=运算符

if (variable is null)
{
    variable = expression;
}

等效于:

variable ??= expression;

??=运算符同??一样为右结合运算符,会像如下计算:

形如:d ??= e ??= f 的表达式
会按照:d ??= (e ??= f) 计算

5.NULL 检查运算符

检查运算符左边的对象是否为null,如果为null,则不会进行右边的运算,直接返回null。

代码如下(示例):

    //表示获取用户的id信息
    //这里用了?. 表示检查UserInfo是否为null
    string id=UserInfo?.Id;
    

6.?[ ] 运算符

这个要和和上面?.运算符一起再介绍一下:
仅当操作数的计算结果为非 NULL 时,
NULL 条件运算符才对其操作数应用成员访问?. 或元素访问?[] 操作;否则,它会返回 null。 即:

  • 如果 a 的计算结果为 null,则 a?.x 或 a?[x] 的结果为 null。
  • 如果 a 的计算结果为非 null,则 a?.x 或 a?[x] 的结果将分别与 a.x 或 a[x] 的结果相同。
        static void Main(string[] args)
        {
            string[] strArr = null;
            string res = strArr?[2];
            Console.WriteLine($"res: {res}");

            int[] intArr = {1,2,3,4,5 };
            var num = intArr?[2];
            Console.WriteLine($"num: {num}");

        	//结果:res:
        	//      num: 3
            Console.ReadLine();
        }

结语

以上就是本文的内容,希望以上内容可以帮助到您,如文中有不对之处,还请批评指正。


参考资料:
C#运算符
?? 和 ??= 运算符
成员访问运算符和表达式

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
没法下载,到这里折腾一把试试。 本文由abc2253130贡献 doc文档可能在WAP端浏览体验不佳。建议您优先选择TXT,或下载源文件到本机查看。 C#(WINFORM)学习 一、 C#基础 基础 类型和变量 类型和变量 类型 C# 支持两种类型:“值类型”和“引用类型”。值类型包括简单类型(如 char、int 和 float 等)、枚举类型和结构类型。引用类型包括类 (Class)类 型、接口类型、委托类型和数组类型。 变量的类型声明 变量的类型声明 每个变量必须预先声明其类型。如 int a; int b = 100; float j = 4.5; string s1; 用 object 可以表示所有的类型。 预定义类型 下表列出了预定义类型,并说明如何使用。 类型 object 说明 所有其他类型的最终 基类型 字符串类型; 字符串是 Unicode 字符序列 8 位有符号整型 16 位有符号整型 32 位有符号整型 64 位有符号整型 示例 object o = null; 范围 string sbyte short int long string s = "hello"; sbyte val = 12; short val = 12; int val = 12; long val1 = 12; -128 到 127 -32,768 到 32,767 -2,147,483,648 2,147,483,647 -9,223,372,036,854,775,808 到 第1页 C#(WINFORM)学习 long val2 = 34L; 到 9,223,372,036,854,775,807 byte ushort 8 位无符号整型 16 位无符号整型 byte val1 = 12; ushort val1 = 12; uint val1 = 12; uint 32 位无符号整型 uint val2 = 34U; ulong val1 = 12; ulong val2 = 34U; ulong 64 位无符号整型 ulong val3 = 56L; ulong val4 = 78UL; float 单精度浮点型 float val = 1.23F;7 位 double val1 = 1.23; double 双精度浮点型 double val2 = ±5.0 × 10?324 ±1.7 × 10 308 0 到 255 0 到 65,535 0 到 4,294,967,295 0 到 18,446,744,073,709,551,615 ±1.5 × 10?45 ±3.4 × 10 38 到 到 4.56D;15-16 布尔型;bool 值或为 真或为假 字符类型;char 值是 一个 Unicode 字符 精确的小数类型, 具有 28 个有效数字 bool val1 = true; bool val2 = false; char val = 'h'; decimal val = bool char decimal DateTime ±1.0 × 10?28 ±7.9 × 10 28 到 1.23M;28-29 变量转换 简单转换: float f = 100.1234f; 可以用括号转换: short s = (short)f 也可以利用 Convert 方法来转换: string s1; s1=Convert.ToString(a); MessageBox.Show(s1); 常用 Convert 方法有: 第2页 C#(WINFORM)学习 C# Convert.ToBoolean Convert.ToByte Convert.ToChar Convert.ToDateTime Convert.ToDecimal Convert.ToDouble Convert.ToInt16 Convert.ToInt32 Convert.ToInt64 Convert.ToSByte Convert.ToSingle Convert.ToString Convert.ToUInt16 Convert.ToUInt32 Convert.ToUInt64 备注 Math 类 常用科学计算方法: C# Math.Abs Math.Sqrt Math.Ro
C/C++期末复习资料大汇总 一、内容概述 在本次上传,我们为您精心整理了关于C/C++的期末复习资料。这些资料涵盖了从基础知识到进阶概念,旨在帮助您全面复习C/C++的相关内容。无论是准备期末考试还是为大作业做准备,这份资料都将为您的学习提供有力的支持。 二、资料详解 基础知识篇:针对C/C++的语法、数据类型、运算符等内容进行了详细的梳理,帮助您打好扎实的基础。 进阶概念篇:深入探讨了指针、函数、文件操作等进阶知识点,为您进一步提升编程能力提供指导。 期末复习题及答案:包含各类期末考试的经典题目及详细答案,让您熟悉考试题型,把握考试重点。 期末大作业指南:针对C/C++的期末大作业,提供了从选题到实现的全程指导,帮助您顺利完成作业。 实战案例集锦:收录了一些经典案例,让您在实践掌握C/C++的应用技巧。 三、适用人群 这份复习资料适用于学习C/C++的各类人群,无论是初学者还是有一定编程基础的学生,都能从获得收益。 四、使用建议 我们建议您先从基础知识开始复习,逐步深入到进阶概念。在掌握基本知识点后,结合复习题进行巩固练习,最后通过大作业和实战案例进一步提升自己的编程能力。 五、特别提示 为了更好地掌握C/C++的知识点,除了复习资料外,实际操作和练习也是非常关键的。希望这份资料能帮助您取得优异的成绩,也欢迎您在学习过程提出宝贵的意见和建议。 最后,感谢您选择我们的复习资料,祝您学习顺利!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值