dynamic的一些使用心得

        dynamic關鍵字纔出來的時候,以爲真是沒什麼用,誰老是和com交互來交互去啊,惟恐避之不及啊。性能

        後來逐漸算是有了一些使用心得,發現這貨還真是犀利啊,故在此舉幾個例子,起拋磚引玉之用。ui

1.替代XXX.GetType().GetProperty("YYY").GetValue(XXX)spa

        static object GetPerson()
        {
            return new Person { Name = "Leo" };
        }    

        有時候不免會遇到這種返回object的倒黴代碼(特別是跟反射有關的時候),這時咱們又要訪問其中的某個屬性,那個費勁啊,如今有了dynamic感受好多了。pwa

            object objPerson = GetPerson();
            var objName =  objPerson.GetType().GetProperty("Name").GetValue(objPerson);
            Console.WriteLine(objName);

            dynamic dynPerson = GetPerson();
            var dynName = dynPerson.Name;
            Console.WriteLine(dynName);

        另外一個好處是性能會獲得一程度的提高:設計

            Watch = new Stopwatch();
            Watch.Start();
            for (int i = 0; i < 1000000; i++)
            {
                objName = objPerson.GetType().GetProperty("Name").GetValue(objPerson);
            }
            Watch.Stop();
            Console.WriteLine(Watch.Elapsed);


            Watch.Restart();
            for (int i = 0; i < 1000000; i++)
            {
                dynName = dynPerson.Name;
            }
            Watch.Stop();
            Console.WriteLine(Watch.Elapsed);

        大體結果以下圖,仍是快了不少的:code

    

2.拯救接手接口沒設計好的代碼的倒黴孩子對象

        好比這裏有N個WCF服務,返回了N個對象的集合,這幾個對象沒啥關係,其實又有一點關係,倒黴孩子又不會讓Entity Framework生成的類自動繼承某個接口(本文裏用本地方法代替WCF服務)。blog

        這裏來舉一個例子,首先有下面2個倒黴的類,一樣string類型的name是能夠提取接口的(這裏真的合適提取麼……),一樣名稱但不一樣類型的ID,徹底無關的Age和Price。繼承

    public class Person
    {
        public int ID { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }

        public static List<Person> GetPersonList()
        {
            return new List<Person>
            {
                new Person{ Name = "Leo1" , Age = 10 },
                new Person{ Name = "Leo2" , Age = 20 },
                new Person{ Name = "Leo3" , Age= 30 }
            };
        }
    }

    public class Car
    {
        public Guid ID { get; set; }

        public string Name { get; set; }

        public double Price { get; set; }

        public static List<Car> GetCarList()
        {
            return new List<Car>
            {
                new Car{ Name = "Focus1" , Price = 100 },
                new Car{ Name = "Focus2" , Price = 200 },
                new Car{ Name = "Focus3" , Price = 300 }
            };
        }
    }

        我用2個static方法返回不一樣類型的List<T>來模擬WCF中最普通的調用。接口

        static void Main(string[] args)
        {
            List<dynamic> list = new List<dynamic>();
            //用本地方法替代WCF服務,您僞裝是經過WCF獲取的list
            Person.GetPersonList().ForEach((p) => list.Add(p));
            TestDynamic2(list,"Leo2");

            list = new List<dynamic>();
            //用本地方法替代WCF服務,您僞裝是經過WCF獲取的list
            Car.GetCarList().ForEach((c) => list.Add(c));
            TestDynamic2(list,"Focus3");

            Console.ReadKey();
        }

        private static void TestDynamic2(List<dynamic> list,string name)
        {
            //能夠無差異的使用ID和Name屬性
            dynamic first = list.OrderBy(d => d.ID).FirstOrDefault(d => d.Name.Contains(name));

            //差異對待不一樣的屬性,這裏供參考,不建議這麼寫,這會致使依賴具體的類型
            if (first is Person)
            {
                Console.WriteLine(first.Age);
            }
            else
            {
                Console.WriteLine(first.Price);
            }
        }

       本文提供了使用dynamic的一點心得,若是有不對的對方,還望各位不吝指出,很是感謝!

相關文章
相關標籤/搜索