C#中?的相关使用
C#中?的相关使用
今天看了几篇博客,学习了一下与?相关的使用,大致分为一下几种:
1. 可空类型
看标题就能够很好的理解这个概念:可以为空的类型。而在C#中可以为空也就是null的类型,都是引用类型,所以?对于引用类型来说,也就没有什么存在的价值了,只能服务于值类型,使得在某些不确定的情况下,值类型拥有更好的适应能力。也就是说,值类型也可以接受null,当然是在使用?的前提下。使用如下,在值类型后添加?即可:
int? a = null;
a = 10;
可以看的出,声明为可空类型的变量,既可以接收null也可以接收正常的值类型。
2. 可空运算符
使用可空运算符这个词可能不是特别的合适,但一时词穷,将就用了。其实就是?. 和?[]罢了。分别用于对象对成员的调用以及数组的索引。对象为空或者数组为空,这种情况还是挺常见的。如果按照平时的写法大致就是。。。
if(object != null){//方法调用
object.method();
}
if(array != null){ //数组索引
int a = array[1];
}
但是现在有了可空运算符之后,能省的就都省了,简洁到飞起来,一句代码搞定。
object?.method();
array?[1];
而且这样的写法更加的容易理解,在执行方法的调用或者素组的索引之前,进行null的判断,如果为null,则后续的操作打断,返回null;不为null,则继续执行。这样的效率相比较if判断也要更高一下。
3. 三元运算符 condition?(true result):(false result)
这个再熟悉不过了,但是之前一直没有和这些归为一类来考虑,只是机械化的使用。不同的是,三元运算符的condition必须为bool类型,为true时,返回true result;false时,返回false result。需要注意的应该就是返回的值一定要和定义类型匹配才行。
4. 空合并运算符 ??
有些情况下,获取的值可能出现null,但获取的null对于后续的程序来说无法使用。好的处理方法,应该就是判断一下获取的值是否为null,为null,那么就赋一个值;不为null,就直接使用获取的值,这样是比较合理的操作。这里使用三元运算符是完全可以进行解决的,如下:
int oneNum = object.num !=null? object.num : 0;
这样获取到oneNum永远都不会为null,对于后续的代码而言,也是相对有好的。虽然三元运算符可以解决,但更简洁的解决方案是使用??:
int oneNum = object.num ?? 0;
当object.num不为null时,返回object.num;object.num为null,则返回0。相比较三元运算符而言,更加的简洁,理解性也高了不少。但是上面的使用存在一个问题,如果object为null呢?这里就可以使用可空运算符来判断,如下:
int oneNum = object?.num ?? 0;
这样就保证了在ojbect为null的情况下,也不会出错了。
总结
null在很多情况下,对于程序而言都是不友好的,我们也极力地避免null的出现。相比较使用各种判断语句而言,?的出现无疑让代码精简了不少,理解性也提高了很多。而且它们之间的嵌套使用(像最后一个例子)在复杂的判断中优势更加的明显。
C#中?的相关使用的更多相关文章
- 理解CSV文件以及ABAP中的相关操作
在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...
- Spring Framework------>version4.3.5.RELAESE----->Reference Documentation学习心得----->Spring Framework中web相关的知识(概述)
Spring Framework中web相关的知识 1.概述: 参考资料:官网documentation中第22小节内容 关于spring web mvc: spring framework中拥有自 ...
- storm-kafka组件中KafkaOffsetMetric相关统计指标说明
storm-kafka组件中KafkaOffsetMetric相关统计指标说明 storm-kafka是storm提供的一个读取kakfa的组件,用于从kafka队列中消费数据.KafkaOffset ...
- Linux中mod相关的命令 内核模块化 mod相关命令都是用来动态加载内核模块/驱动程序模块
Linux中mod相关的命令 内核模块化 mod相关命令都是用来动态加载内核模块/驱动程序模块 http://baike.baidu.com/link?url=lxiKxFvYm-UfJIxMjz ...
- 补充:sql server 中的相关查询、case函数
相关查询(在同一个表中) 相关查询类似子查询,但是又不同于子查询:子查询中的子条件可以单独查出数据,但是相关查询的子条件不能查处数据.(可以理解成C#中for的穷举法,第一个for走一个,第二个for ...
- c语言中数组相关问题
c语言中数组相关问题: 1.数组基本定义: 相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,然后用编号区分他们的变量的集合,这个名字称为数组名,编号称为下标.组成数组 ...
- 【Socket编程】Java中网络相关API的应用
Java中网络相关API的应用 一.InetAddress类 InetAddress类用于标识网络上的硬件资源,表示互联网协议(IP)地址. InetAddress类没有构造方法,所以不能直接new出 ...
- c语言中条件编译相关的预编译指令
一. 内容概述 本文主要介绍c语言中条件编译相关的预编译指令,包括#define.#undef.#ifdef.#ifndef.#if.#elif.#else.#endif.defined. 二.条件编 ...
- (笔记)Linux内核中内存相关的操作函数
linux内核中内存相关的操作函数 1.kmalloc()/kfree() static __always_inline void *kmalloc(size_t size, gfp_t flags) ...
- electron-builder中NSIS相关配置
electron-builder中NSIS相关配置 相比较于electron-packager打包,使用electron-builder打包使得包体积更小.在electron-builder中,对于N ...
随机推荐
- P5496 【模板】回文自动机(PAM)
做一下强制在线处理即可 #include <cstdio> #include <algorithm> #include <cstring> using namesp ...
- HDU 6102 - GCDispower | 2017 Multi-University Training Contest 6
个人感觉题解的复杂度很玄,参不透,有没有大佬讲解一下- - /* HDU 6102 - GCDispower [ 数论,树状数组] | 2017 Multi-University Training C ...
- 【EXE报错】win10运行C#程序保存报错:HTTP 无法注册URL ,进程不具有此命名空间的访问权限
在win10系统运行C#程序出现以下报错 异常信息 [1]异常信息:HTTP 无法注册 URL http://+:13000/Core/Real/HandheldService/.进程不具有此命名空间 ...
- PAT 甲练习 1003 Emergency
1003 Emergency (25 分) As an emergency rescue team leader of a city, you are given a special map of y ...
- 小米oj 数组差(挺好的题)
数组差 序号:#46难度:困难时间限制:1000ms内存限制:10M 描述 给定一个整数数组,找出两个不重叠的子数组A和B,使两个子数组元素和的差的绝对值 |SUM(A) - SUM(B)| 最大. ...
- apache和tomcat有什么不同
前言 apache是web服务器,tomcat是应用(java)服务器,它只是一个servlet容器,可以认为是apache的扩展,但是可以独立于apache运行. 换句话说,apache是一辆卡车, ...
- [vbs]脚本启动
Set ws = CreateObject("Wscript.Shell") ws.run "cmd.exe /c start tool.exe config_tence ...
- java什么时候进行垃圾回收,垃圾回收的执行流程
java的垃圾回收分为 三个区域新生代 老年代 永久代 一个对象实例化时 先去看伊甸园有没有足够的空间如果有 不进行垃圾回收 ,对象直接在伊甸园存储.如果伊甸园内存已满,会进行一次minor gc然后 ...
- Qt Model/View 的简单说明
目录: (一) Qt Model/View 的简单说明 .预定义模型 (二)使用预定义模型 QstringListModel例子 (三)使用预定义模型QDirModel的例子 (四)Qt实现自定义模型 ...
- ORA-12899 导入失败
主要是目标数据库的字符集与导入文件的字符集不符 SQL>SHUTDOWN IMMEDIATE SQL>STARTUP MOUNT SQL>ALTER SYSTEM ENABLE RE ...