C# 6.0 的那些事

网友投稿 653 2022-08-28

C# 6.0 的那些事

C# 6.0 的那些事

这两天期中考试没时间去看Connect();直播,挺可惜的,考完后补看了Connect(); 把C#6.0的新东西总结一下。

自动属性初始化 (Initializers for auto-properties)

以前我们是这么写的

为一个默认值加一个后台字段是不是很不爽,现在我们可以这样写

只读属性的初始化(Getter-only auto-properties)

像用户ID这种只读属性,我们以前是这样写的

现在我们可以这样写

只读属性可以和标了readonly的字段一样在构造函数里面赋值。

用Lambda作为函数体 (Expression bodies on method-like members)

平时总是有一些短小精悍的代码,但我们不得不把他们放到两个括号中,现在我们可以这么写

Lambda表达式用作属性 (Expression bodies on property-like function members)

这种用法同样可以用于属性

字符串嵌入值 (String interpolation)

这个叫法有点怪,看个例子就明白了,上面那个string.Format其实可以这样写,不仅写起来方便,而且可读性也非常好。

如果要用到格式控制,和以前一样加上就可以了。

Using静态类 (Using static)

如果一个静态类里面是一堆方法,比如Math 可以不用写类名,直接调用他的静态方法

有人说这有破坏面向对象的嫌疑,我倒觉得这让C#在函数式编程上更进一步,至于到底是怎样,time will tell.

值得一提的是,这种using 也会引入扩展方法,之前using System.Linq 会把这个命名空间下所有的扩展方法引入,如果只需要一部分 (比如Enumerable),这种用法会很方便。

空值判断 (Null-conditional operators)

这种写法相信有非常多的朋友用过,经常为了一个是否为空的问题搞得代码非常难看,比如视频里的那个

再举个例子,我们要获取一个列表的长度

这种写法真是太恶心了,在C#6.0中,我们可以这样写

从这里也可以看出这种操作符的一个规则:如果对象为空,则整个表达式的值为空。

后面的成员访问不限于方法,还可以是属性,索引器等。

给个实际应用的例子,在触发事件时,经常见到这样的写法,一个委托在调用前总是要判断是否为空

现在我们可以这样

如果PropertyChanged为null,那这句就什么也不做。

nameof表达式 (nameof expressions)

在方法参数检查时,经常会见到这样的代码

里面有那个role是我们手写的字符串,在给role改名时,很容易把下面的那个字符串忘掉,C#6.0解决了这个问题,看看新写法

带索引的对象初始化器 (Index initializers)

对象初始化器在C#3.0就已经有了,C#6.0的对象初始化器加入了对索引器的支持,使得字典一类的东西也可以轻松初始化

这是一个Json.NET使用的例子

异常筛选器 (Exception filters)

这个在VB和F#中早就有的功能也加进来了,看看用法

在微软的文档中还给出了另一种用法,这个异常会在日志记录失败时抛给上一层调用者

catch和finally 中的 await (Await in catch and finally blocks)

这是另一个和异常相关的特性,使得我们可以在catch 和finally中等待异步方法,看微软的示例

无参数的结构体构造函数 (Parameterless constructors in structs)

在之前版本的C#中是不允许结构体拥有无参构造函数的,在C#6.0中是允许的,但需要注意一点,通过new得到的结构体会被调用构造函数,而通过default得到的不会调用

看看这个例子

首先是一个结构体,通过两种不同的方式创建,然后输出

不见的功能

Primary constructor和 out参数定义变量那个不见了,有说法是cut掉了,微软真是纠结。。

详情: Changes to the language feature set

总体感觉C#6.0加入的更多是语法糖,语言本身没有太多新的概念,语法糖的加入会让C#程序员写出的代码更优美,更有生产力,希望C#越做越好!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Elasticsearch 的 30 个调优
下一篇:MySQL 时间类型 datetime、bigint、timestamp,选哪个?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~