zoukankan      html  css  js  c++  java
  • C#编程(十六)----------匿名类型

    匿名类型

    var和new关键字一起使用,可以创建匿名类型.

    匿名类型提供了一种方便的方法,可用来将一组只读属性封装到单个对象中,而无需首先显式定义一个类型。 类型名由编译器生成,并且不能在源代码级使用。 每个属性的类型由编译器推断

    public class BookAsGood

        {

            // 定义一组私有成员变量

            private string m_name;

            private double m_price;

            // 为成员变量设置属性

            public string Name

            {

                get

                {

                    return this.m_name;

                }

                set

                {

                    this.m_name = value;

                }

            }

            public string Price

            {

                get

                {

                    return this.m_price;

                }

                set

                {

                    this.m_price = value;

                }

            }

        }

    这只是引入了两个字段的量,如果是多个字段,代码量可想而知,所以就引入了匿名类型.

    匿名类型的使用:如果要定义一个包含名字和价格的书对象.

    var book = new {Name=”C#”,Price=100};

    这会生成一个包含Name和Price属性的对象.

    如果我们再创建一个书的对象

    var bookA = new {Name=”C++”,Price=10};

    其中,book和bookA的类型是相同的.我们可以这样设置:

    book=bookA;

    如果设置的值来自于另一个对象,例如

    BookAsGood b=new BookAsGood();

    var book = new {b.Pame,b.Price};

    book对象有Name和Price属性.

    在访问的时候可以直接和访问对象的方法一样:

    Console.WriteLine(book.Name+”----”+book>price);

    但是如果是这样:

    book.Name=”C”;//这是错误的

    尾音这里的book的各个属性只实现了get而没有实现set.所以不能赋值.为什么没有实现set?

    不管怎么说,为了程序的安全性,尽量不要使用匿名类型,除非你深刻的明白匿名类型.

    匿名类型和隐式类型的区别

    var age=90;

    我们能根据右边的表达式,出短处等号左边的变量age是int类型.这是隐式类型

    var book = new { Name = "C#", Price = 100};

    上面的book就是一个匿名类型。其中的Name = "C#"和Price = 100又可以分别看作是隐式类型变量。

  • 相关阅读:
    美团霸面---我想说说心里话。
    docker在ubuntu14.04下的安装笔记
    ubuntu14.04 upgrade出现【Ubuntu is running in low-graphics mode】问题的一个解决办法
    Python2和Python3在windows下共存
    Python发送邮件
    Python在安装第三方模块遇到的问题及解决办法
    127.0.0.1和localhost完全相等吗?
    vim总结
    linux shell学习笔记
    Jenkins +JUnit
  • 原文地址:https://www.cnblogs.com/FinleyJiang/p/7602164.html
Copyright © 2011-2022 走看看