一、可空类型修饰符(?)
C#2.0里面实现了Nullable数据类型
//A.比如下面一句,直接定义int为null是错误的,错误提示为无法将null转化成int,因为后者是不可以为null的值类型。 private int getNum = null; //B.如果修改为下面的写法就可以初始指为null,在特定情况下?等同于基础类型为Nullable。 private int? getNum = null; private Nullable<int> getNumNull = null;
二、三元运算符(?:)
需要if语句来判断,当Request.Params["para"]不为null时,取出para的值。
string strParam =Request.Params["para"]; if ( strParam== null ) { strParam= ""; }
用三元运算符?简化写法,取出para的值。
string strParam=Request.Params["para"] == null ? "":Request.Params["para"];
三、null合并运算符(??)
?? 运算符称为“ null 合并运算符”,用于定义可以为 null 值的类型和引用类型的默认值。合并运算符为类型转换定义了一个预设值,以防可空类型的值为Null。
如果此运算符的左操作数不为 null,则此运算符将返回左操作数;否则返回右操作数。
int? x = null;//定义可空类型变量 int? y = x ?? 1000;//使用合并运算符,当变量x为null时,预设赋值1000 Console.WriteLine(y.ToString()); //1000
null 合并运算符为右结合运算符,即操作时从右向左进行组合的。如,“a??b??c”的形式按“a??(bb??cc)”计算。
如果在尝试将可以为 null 值的类型分配给不可以为 null 值的类型时没有使用 ?? 运算符,则会生成编译时错误。如果使用强制转换,且当前还未定义可以为 null 值的类型,则会引发InvalidOperationException 异常。
//A.定义getNum为null,输出结果为0 private int? getNum = null; Console.WriteLine(getNum ?? 0); //B.定义getNum为1,输出结果为1 private int getNum = 1; Console.WriteLine(getNum ?? 0);
四、NULL条件运算符(?.)
在C# 6.0中,引入了一个 ?. 的运算符。
如果对象为NULL,则不进行后面的获取成员的运算,直接返回NULL
void Main() { //首先我们定义全局变量Person对象,有可能p为null的情况下取值。 Person p = null; string telePhoneNo = string.Empty; //定义telePhoneNo //取Person的telePhoneNo //A.初始写法,if条件判断 if (p != null) { if (p.Secret != null) { telePhoneNo = p.Secret.TelePhoneNo; } } //B.三元运算符写法,单问号? telePhoneNo = p != null ? (p.Secret != null ? p.Secret.TelePhoneNo : "") : "";
//C. NULL检查运算符?. telePhoneNo = p?.Secret?.TelePhoneNo ?? ""; Console.Write(telePhoneNo); } public class SecretByMySelf { public string Password { get; set; } public string TelePhoneNo { get; set; } } public class Person { public string Name { get; set; } public SecretByMySelf Secret { get; set; } }
五、?[]"运算符:
用于在执行成员访问 (?.) 或索引 (?[) 操作之前,测试是否存在 NULL。 这些运算符可帮助编写更少的代码来处理 null 检查,尤其是对于下降到数据结构。
int? count = customers?[0]?.Orders?.Count(); // null if customers, the first customer, or Orders is null