C#可空类型

2023-11-20 21:30
文章标签 c# 类型 .net netcore 可空

本文主要是介绍C#可空类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在C#中,可空类型(Nullable types)允许值类型(比如int, double, bool等)接受null值。这是特别有用的,因为在很多应用程序中,如数据库交互和数据解析,值类型的字段可能需要表示没有值(null)的状态。

使用可空类型

可空类型是通过在值类型后面添加一个问号(?)来声明的。例如:

int? nullableInt = null;
double? nullableDouble = null;
bool? nullableBool = null;
DateTime? nullableDateTime = null;

这里,nullableInt, nullableDouble, nullableBool, nullableDateTime都是可空类型的变量,一开始它们都被赋予了null值。

可空类型的属性和方法

可空类型有两个非常有用的属性和几个方法:

  • HasValue属性:如果可空类型有一个非null的值,这个属性返回true
  • Value属性:提供可空类型的值。在尝试访问Value属性时,如果HasValuefalse,则会抛出一个InvalidOperationException

例如:

int? nullableInt = 5;if (nullableInt.HasValue)
{Console.WriteLine($"The value of nullableInt is: {nullableInt.Value}");
}
  • GetValueOrDefault()方法:如果可空类型有值,则返回该值,否则返回默认值(对于数值类型,默认值通常是0,对于布尔值是false)。

可空类型与运算符

C# 对可空类型进行了操作符重载,这意味着你可以像使用非可空类型一样使用+, -, *, /等运算符。如果参与运算的任何一方是null,那么结果将是null

int? a = null;
int? b = 10;
int? c = a + b; // c will be null

可空类型的协变和比较

你可以使用标准的比较运算符(==, !=, <, >, <=, >=)来比较可空类型,如果任一操作数为null,则比较运算符将返回false,除了!=,当两边都是null时会返回false

可空类型与null合并运算符

null合并运算符(??)是用于可空类型的特别有用的运算符。它提供了一种快捷方式来返回可空类型的值,或在可空类型的值为null时返回一个默认值。

int? nullableInt = null;
int myValue = nullableInt ?? 0; // myValue will be 0

在这个例子中,由于nullableIntnullmyValue将会被赋值为0

可空类型和null条件运算符

从C# 6.0开始,你还可以使用null条件运算符(?.),它允许你在尝试访问对象的成员之前检查这个对象是否为null。如果对象是null,则不执行成员访问,整个表达式返回null

int? length = nullableString?.Length; // 如果nullableString不是null,则返回字符串的长度,否则返回null

总结

可空类型在C#中非常有用,尤其是在处理数据库和其他可能返回不确定值的外部数据源时。通过使用可空类型及其相关的运算符和方法,你可以编写更健壮和错误处理更加优雅的代码。

在C#中,将可空类型作为函数参数意味着你可以传递一个具有特定值的参数,或者如果合适的话,可以传递一个null值。这在你不确定是否总是有一个合法值传递给函数或者当你想要表示一个可选的或不存在的值时特别有用。

使用可空类型作为函数参数

下面是一个使用可空类型作为函数参数的例子:

public void PrintDetails(string name, int? age)
{if (age.HasValue){Console.WriteLine($"Name: {name}, Age: {age.Value}");}else{Console.WriteLine($"Name: {name}, Age: Not provided");}
}

在这个函数中,age参数是一个可空的int类型,这意味着你可以传递一个int值或者null给这个参数。函数内部使用HasValueValue属性来确定是否提供了一个有效的年龄值。

调用带有可空类型参数的函数

调用上面的函数可以像下面这样:

PrintDetails("Alice", 25);   // 输出: Name: Alice, Age: 25
PrintDetails("Bob", null);    // 输出: Name: Bob, Age: Not provided

可空类型作为可选参数

另一个常见的场景是使用可空类型作为函数的可选参数。这样可以让你省略该参数,而不是传递一些特定的值,比如0false或者其他“魔法数字”来表示“无值”。

public void PrintDiscount(string product, double? discount = null)
{if (discount.HasValue){Console.WriteLine($"Product: {product}, Discount: {discount.Value}%");}else{Console.WriteLine($"Product: {product}, No discount applicable");}
}

在这个例子中,discount参数是可选的,并且默认为null。这意味着如果你不提供discount参数,它将默认为null

PrintDiscount("Laptop"); // 输出: Product: Laptop, No discount applicable
PrintDiscount("Laptop", 15.0); // 输出: Product: Laptop, Discount: 15%

可空类型参数与方法重载

当你设计函数时,可空类型可以是方法重载的一个替代方案。例如,你可能会有两个方法的重载版本,其中一个接受一个int参数,另一个不接受任何参数。使用可空类型参数,你可以只有一个方法,而不是重载它。

// 两个重载方法
public void SetAge(int age) { /*...*/ }
public void SetAge() { /*...*/ }// 使用一个可空类型参数的单个方法
public void SetAge(int? age = null) 
{if (age.HasValue){// 设置年龄}else{// 采取不设置年龄的行动}
}

小心处理可空类型参数

当使用可空类型作为参数时,务必在函数内部检查参数是否有值,以避免NullReferenceException异常。这通常是通过HasValue属性和??运算符来完成的。

使用可空类型作为参数可以提高函数的灵活性,使得调用者可以更明确地说明是否提供了一个值。然而,也要注意不要过度使用它们,因为在某些情况下,过多的可空类型参数可能会使得函数调用变得复杂并减少代码的可读性。

这篇关于C#可空类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/397543

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla