C#学习笔记之匿名类型

发布时间:2019-09-02编辑:脚本学堂
本文介绍下,C#的基础内容,有关C#匿名类型的相关知识,有需要的朋友,参考下吧。

var 关键字,与new关键字一起使用可以创建匿名类型。
例如,
 

复制代码 代码示例:

namespace 匿名类型
{
    class A
    {
        public string AA { get; set; }
        public string BB { get; set; }
    }


    class Program
    {
        static void Main(string[] args)
        {
            A a = new A();
            a.AA = "123";
            a.BB = "456";
            var v = new { a.AA, a.BB };
            Console.WriteLine(v.AA);
            Console.WriteLine(v.BB);
            Console.Read();
        }
    }
}

输出结果:
123
456

说明:
匿名类型没有名称,编译器为该类型伪造一个名称,但只有编译器能使用它,匿名类型继承自Object类,该类的定义从初始化器中推断。

C#匿名类型,包括介绍KeyPair这里是一个变量名等方面。

在C#里有这样一些类型,它是作为临时储存数据的,生命周期只在这个方法内,方法结束了,这个类型的生命周期也没有了。那么这里我们就可以使用一个C#匿名类型。
 

var KeyPair = new {Key=”yuyi”,Value=”20”};


    这个KeyPair就是一个C#匿名类型,注意KeyPair这里是一个变量名,并不是类的名字。嗯,前面还有一个var,这又是什么呢?这是C# 3.0里面的隐式局部变量。

    刚才说了,C#匿名类型是没有名字的类型,没有名字你怎么来称呼它,怎么来声明它?但是C#匿名类型真的是没有名字的么?看看C#编译器又在我们背后干了些什么,使用ILDASM打开编译过的程序集,发现多了一个类型:
 

<>f__AnonymousType0<<Key>j__TPar, <Value>j__TPar>


    这个类型是直接继承自System.Object的,并且是internal seald(只在程序集内可见,并且不能被继承)。有心的你也许会发现,这个类型还是一个泛型类型,那么只要我们在使用一个C#匿名类型的时候参数个数,参数名称不发生变化,编译器是不会为我们产生更多的类型的:
 

var KeyPair1 = new { Key="yuyi",Value="Programer"}; 
var KeyPair2 = new { Key="y",Value=3}; 
var KeyPair3 = new { Key=4,Value="abc"};


    上面三个C#匿名类型,编译器只会为我们在背后产生一个新类型,一个泛型的新类型。如果我们将这个C#匿名类型内的属性名修改一下:对
 

var KeyPair1 = new { Key="yuyi",Value="Programer"}; 
var KeyPair2 = new { Key="y",Value1=3};


    就会产生两个新泛型了:
 

<>f__AnonymousType0<<Key>j__TPar, <Value>j__TPar>
<>f__AnonymousType1<<Key>j__TPar, <Value1>j__TPar>


    看看,这个命名还是有规律可循哦。如果你给这个C#匿名类型添加一个新属性呢?这样又产生了一个新类型了:
 

<>f__AnonymousType1<<Key>j__TPar, <Value1>j__TPar, <Test>j__TPar>
 

    嗯,这个问题还是值得关注的,所以我们在使用C#匿名类型的时候应该尽量保持“一致性”:属性个数一致(这个尽量了)。属性名称一致,这个比较好把握。

    只要保持了这个一致性,编译器会为一致的产生同一个类型,而不一致的会新产生一个类型,如果不一致的太多我想是不是会产生“代码爆炸”而致使”WorkSet”过大造成性能的损失?这个只是个人认为,未测试。
 
 有关C#匿名类型的内容,就介绍这些了,希望对大家有所帮助。