💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
# 可以为 null 的类型(C# 编程指南) 可以为 null 的类型是 [System.Nullable<T>](https://msdn.microsoft.com/zh-cn/library/b3h38hb0.aspx) 结构的实例。可以为 null 的类型可以表示其基础值类型正常范围内的值,再加上一个 **null** 值。例如,Nullable<Int32> 读作“可以为 null 的 Int32”,可以将其赋值为 -2147483648 到 2147483647 之间的任意值,也可以将其赋值为 **null** 值。可以赋给 Nullable<bool> 的值包括 [true](https://msdn.microsoft.com/zh-cn/library/eahhcxk2.aspx)、[false](https://msdn.microsoft.com/zh-cn/library/67bxt5ee.aspx) 或 [null](https://msdn.microsoft.com/zh-cn/library/edakx9da.aspx)。在处理数据库和其他包含不可赋值的元素的数据类型时,将 **null** 赋值给数值类型或布尔型的功能特别有用。例如,数据库中的布尔型字段可以存储值 **true** 或 **false**,或者,该字段也可以未定义。 ``` class NullableExample { static void Main() { int? num = null; // Is the HasValue property true? if (num.HasValue) { System.Console.WriteLine("num = " + num.Value); } else { System.Console.WriteLine("num = Null"); } // y is set to zero int y = num.GetValueOrDefault(); // num.Value throws an InvalidOperationException if num.HasValue is false try { y = num.Value; } catch (System.InvalidOperationException e) { System.Console.WriteLine(e.Message); } } } ``` 此示例将显示输出: num = Null Nullable object must have a value. 有关更多示例,请参见[使用可以为 null 的类型(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/2cf62fcy.aspx)。 ## 可以为 null 的类型概述 可以为 null 的类型具有以下特性: * 可以为 null 的类型表示可被赋值为 **null** 值的值类型变量。无法创建基于引用类型的可以为 null 的类型。(引用类型已支持 **null** 值。) * 语法 **T?** 是 [Nullable<T>](https://msdn.microsoft.com/zh-cn/library/b3h38hb0.aspx) 的简写,此处的 **T** 为值类型。这两种形式可以互换。 * 为可以为 null 的类型赋值的方法与为一般值类型赋值的方法相同,如 int? x = 10; 或 double? d = 4.108。对于可以为 null 的类型,也可向其赋 **null**: int? x = null. 值 * 如果基础类型的值为 **null**,请使用 [Nullable<T>.GetValueOrDefault](https://msdn.microsoft.com/zh-cn/library/72cec0e0.aspx) 方法返回该基础类型所赋的值或默认值,例如 int j = x.GetValueOrDefault(); * 将 [HasValue](https://msdn.microsoft.com/zh-cn/library/sksw8094.aspx) 和 [Value](https://msdn.microsoft.com/zh-cn/library/ydkbatt6.aspx) 只读属性用于测试是否为空和检索值,如下面的示例所示:if(x.HasValue) j = x.Value; * 如果此变量包含值,则 **HasValue** 属性返回 **true**;或者如果是 **null** 则返回 **false**。 * 如果已赋值,则 **Value** 属性返回该值。否则,将引发 [System.InvalidOperationException](https://msdn.microsoft.com/zh-cn/library/system.invalidoperationexception.aspx)。 * **HasValue** 的默认值为 **false**。 **Value** 属性没有默认值。 * 还可以将 **==** 和 **!=** 操作数用于可为 null 的类型,如下面的示例所示:if (x != null) y = x; * 使用 **??** 算符分配默认值,在将当前值为 **null** 的可以为 null 的类型赋值给不可以为 null 的类型时,将应用该默认值,如 int? x = null; int y = x ?? -1; * 不允许使用嵌套的可以为 null 的类型。将不编译下面一行:Nullable<Nullable<int>> n; ## 相关章节 有关更多信息: * [使用可以为 null 的类型(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/2cf62fcy.aspx) * [装箱可以为 null 的类型(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/ms228597.aspx) * [?? 运算符(C# 参考)](https://msdn.microsoft.com/zh-cn/library/ms173224.aspx) ## C# 语言规范 有关详细信息,请参阅 [C# 语言规范](https://msdn.microsoft.com/zh-cn/library/ms228593.aspx)。该语言规范是 C# 语法和用法的权威资料。 ## 请参阅 [Nullable](https://msdn.microsoft.com/zh-cn/library/system.nullable.aspx) [C# 编程指南](https://msdn.microsoft.com/zh-cn/library/67ef8sbd.aspx) [Visual C#](https://msdn.microsoft.com/zh-cn/library/kx37x362.aspx) [C# 参考](https://msdn.microsoft.com/zh-cn/library/618ayhy6.aspx) [“lifted 正确意味着什么?](http://go.microsoft.com/fwlink/?LinkId=112382)