• C#3.0智能的编译器


    智能的编译器

    C#3.0中,编译器变的越来越智能,我们不用提供给它完整的信息,仅需要提供必要的信息,编译器就可以进行推断为我们补全未提供的信息

       

    自动实现的属性

    在之前我们生成一个类时需要有一个字段,但是字段一般不对外暴露,所以还会有一个对应的属性。类似下图

    一个简单的name,我们就要写这么多代码,明显是让人沮喪的,而现在我们仅要下面这样一行简单的代码就可以,而在内部,实际上还是会有一个对应的字段,并且字段名看起来乱七八糟的,当然这是为了保证不会命名冲突,但是开发人员看不到啊,可以轻松的使用属性

       

    隐式的局部变量

    实际上我更喜欢说是类型推断,有时我们生明一个变量时,它的类型非常的长,比如下图,仅仅只是创建一个键值对,就要写这么长的代码。

    如果使用了类型推断的话,我们可以使用var关键词来替换局部变量前面的类型,如下图 我们成功的简化了代码,但是实际上是编译器帮我们做了类型推断,鼠標放上去,可以看到类型还是Dictionary<string,string>。

       

    和它的名称一样,隐式的局部变量仅可以在定义局部变量中使用,属性,字段都不可以。而且在表达式中我们必须明确的给定类型是什么。不可以是模拟两可的。也不可以为null

       

       

    初始化器

    初始化器分为对象初始化器与集合初始化器,在之前我们创建一个类的实例并为其成员赋值也是比如繁瑣的,如果没有構造函數的话我们无法在一个表达式中完成初始化操作。看起来应该如下图一样

    而有了对象初始化器我们可以换一种写法,在后面加一个大括号,然后进行赋值即可。甚至可以发现小括号都被忽略了,当然这是有要求的,必须有无参的構造函數才可以。

    当然,这也是编译器的功劳,编译后的代码,和我们之前并无区别。只是帮我们做了这些繁瑣的事

       

    集合初始化器和上面是类似的,我们创建一个集合的时候,要调Add方法一个一个的赋值 ,现在一切变得简单起来

    使用集合初始器只要类型有Add方法或者实现Ienumerable,为什么要有这个限制呢,因为还是编译器在背后帮我们一个一个的Add…..

       

    隐式类型的数组

    在创建一个数组的时候,我们要指定数组的类型,比如

    Var array = new string[3]{"1","2","3"};

    而现在写法变了,我们如果刚开始就初始化数组的话那么仅仅只要像下面这样就可以

    Var array = new []{"1","2","3"}

    编译器会要根据我们提供的项的类型进行推断,然后从而确定数组的话,当然我们给的所有项类型都要是一致的。

       

    匿名类型

    有时会有一种苦惱,我们需要一个简单的对象,并且只在一个地方使用一次。而又不得不为它去写一个类。现在这些得到了解决,就是匿名类型。

    看看下图做了什么,我们创建了一个变量,但是它的类型是什么呢?在之前的理解中,这样是不对的,而现在它是匿名类型的。IDE也给了我们足够的提示,我们可以直接per.Name这样的去使用。

    我们可以多次创建匿名类型,对于属性名相同,类型也相同的,编译器会为我们生成一个类。而属性名相同,类型不同的,会产生两个不同的类型,它们是同一个泛型类型生成的。

    而我们写的那些属性,是只读属性,创建后,不可以再进行更改其值所以是不易变的也是线程安全的,

  • 相关阅读:
    获得 Web Service 方法的描述信息
    make menuconfig 报错
    汇编调用c函数为什么要设置栈
    UBoot Makefile文件分析
    UBoot启动过程完全分析(转)
    (转)在fedora12下用crosstoolng建立armlinux交叉编译环境
    UBoot编译过程完全分析(转)
    雷军:给互联网创业者的“七字”建议
    uboot根目录下makefile
    Redhat 5 配置Samba服务器
  • 原文地址:https://www.cnblogs.com/LiangSW/p/7327644.html
Copyright © 2020-2023  润新知