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中,我们可以这样写

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

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

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

  现在我们可以这样

  如果PropertyChangednull,那这句就什么也不做。

  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#越做越好!

时间: 2024-09-28 15:51:50

C# 6.0 的那些事的相关文章

HTTP 2.0的那些事

转自:http://www.admin10000.com/document/9310.html 在我们所处的互联网世界中,HTTP协议算得上是使用最广泛的网络协议.最近http2.0的诞生使得它再次互联网技术圈关注的焦点.任何事物的消退和新生都有其背后推动的力量.对于HTTP来说,这力量复杂来说是各种技术细节的演进,简单来说是用户体验和感知的进化.用户总是希望网络上的信息能尽可能快的抵达眼球,越快越好,正是这种对“快”对追逐催生了今天的http2.0. 1. HTTP2.0的前世 http2.0

isource git使用手册 内源那些事

iSource Git使用    3.0 内源那些事 http://rnd-isourceb.huawei.com/groups/28437/discources/56848 iSource在线帮助目录 http://rnd-isourceb.huawei.com/help/huawei_help/code_support/isource_4 http://rnd-isourceb.huawei.com/help/huawei_help/code_support/Index 1       下载

BZOJ4817 [Sdoi2017]树点涂色

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:BZOJ4817 正解:$LCT$+线段树 解题报告: 考虑操作$1$很类似$LCT$中的$access$操作,我们可以借助$LCT$的复杂度证明,来保证用$LCT$的实现方式来完成本题的操作复杂度的正确性. 我们维护每个点到根的权值,用线段树维

BZOJ4811 [Ynoi2017]由乃的OJ

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:BZOJ4811 正解:树链剖分+线段树 解题报告: 因为位与位之间互相独立,考虑直观做法,对于每一位维护两个变量,分别表示这一位输入$0$.$1$之后会变成的值. 这个复杂度是$O(knlog^2n)$,显然不能通过. 但是我们不难发现,对于不

BZOJ4403 序列统计

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:BZOJ4403 正解:$Lucas$定理+组合数学 解题报告: 考虑这类不降的问题,我们通常把第$i$个数$+i$变成求升序序列问题. 那么权值范围变成了$[l+1,r+n]$,一共$r-l+n$个数,我们要选$i$个数的话就是$C_{r-l+

BZOJ1951 [Sdoi2010]古代猪文

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:BZOJ1951 正解:中国剩余定理+费马小定理+$Lucas$定理 解题报告: 这道题可以说是数论+组合大综合题- 题目求的是$\sum_{d|n} g^{C_n^d}$,模数$p$是质数(特判$g=p!$),根据费马小定理,我们可以把幂上的数

codeforces291E Tree-String Problem

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:codeforces291E 正解:哈希+倍增 解题报告: 突然发现我似乎搞复杂了- 不管了,先讲一讲我的做法好了. 因为字符最多只有$3*10^5$个,那么把字符拆成一个个点,构出一张新图,又因为题目中有限制,必须是一条从上往下的路径, 所以对

codeforces781D Axel and Marston in Bitland

题目链接:codeforces781D 正解:$bitset$+状压$DP$ 解题报告: 考虑用$f[t][0.1][i][j]$表示从$i$出发走了$2^t$步之后走到了$j$,且第一步是走的$0$或者$1$,这个状态是否存在. 转移式子的话就是$f[t][z][i][j]$$|=$$f[t-1][z][i][k]$ & $f[t-1][z$ ^ $1][k][j]$. 但是复杂度太高了,我们考虑压位,因为反正每个状态都只记录了$0$.$1$,那么我还不如把最后那一维(也就是上面的$j$)那一

游戏公司通用屏蔽字列表

#都是正则表达式,Python下可直接导入 #公用过滤表(命名与聊天频道都屏蔽) CommonFilter = { "[hhH][^a-zA-Z0-9一-龥]{0,10}[ttT][^a-zA-Z0-9一-龥]{0,10}[ttT][^a-zA-Z0-9一-龥]{0,10}[ppP][^a-zA-Z0-9一-龥]{0,10}[::][^a-zA-Z0-9一-龥]{0,10}[//][^a-zA-Z0-9一-龥]{0,10}[11][^a-zA-Z0-9一-龥]{0,10}[66][^a-zA-Z