目录 [−]
- 自动属性初始化 (Initializers for auto-properties)
- 只读属性的初始化(Getter-only auto-properties)
- 用Lambda作为函数体 (Expression bodies on method-like members)
- Lambda表达式用作属性 (Expression bodies on property-like function members)
- 字符串嵌入值 (String interpolation)
- Using静态类 (Using static)
- 空值判断 (Null-conditional operators)
- nameof表达式 (nameof expressions)
- 带索引的对象初始化器 (Index initializers)
- 异常筛选器 (Exception filters)
- catch和finally 中的 await (Await in catch and finally blocks)
- 无参数的结构体构造函数 (Parameterless constructors in structs)
- 不见的功能
薜定谔的朱朱总结的C# 6.0的新特性。
原文地址: 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掉了,微软真是纠结。。