您好,登錄后才能下訂單哦!
本篇文章主要介紹泛型的應(yīng)用。
泛型是.NET work 2.0 版類庫就已經(jīng)提供的語法,主要用于提高代碼的可重用性、類型安全性和效率。
泛型的定義
下面定義了一個(gè)普通類和一個(gè)泛型類,我們可以明確看到泛型類和普通類最大的區(qū)別就是多了一個(gè)<T>。
所以,這個(gè)<T>就標(biāo)記了,這個(gè)類是泛型類。其中這個(gè)T,也可以寫成A,B,C,D或其他字符。
public class Generic { public String Name; } public class Generic<T> { public T Name; }
泛型,顧名思義,就是泛指的類型。好比男人,女人,白人,黑人,可以泛稱為【人】。
但類型只能是一個(gè)類型。 那么泛型和類型之間是什么關(guān)系呢?
其實(shí)很簡單,泛型在定義的時(shí)候,是泛指類型;在使用的時(shí)候,就需要被指定,到底使用哪個(gè)類型。
即,使用時(shí),就不在是泛指類型,而是特定類型。
好比,定義時(shí),定義了一個(gè)人。但在使用時(shí),必須明確指定,到底是黑人還是白人。
泛型的使用
泛型類跟普通類的使用方式一樣,都需要實(shí)例化對(duì)象,再由對(duì)象來調(diào)用內(nèi)部的屬性或方法。
下面代碼實(shí)例化了泛型Generic,實(shí)例化時(shí),還指定了該泛型Generic的指定類型為String。
所以要給泛型Generic的屬性Name賦值,就需要賦值字符串類型的值。
public static void Excute() { Generic<String> gs = new Generic<String>(); gs.Name = "Kiba518"; }
下面代碼定義了一個(gè)Int類型的泛型Generic。
public static void Excute() { Generic<int> gs = new Generic<int>(); gs.Name = 518; }
泛型的默認(rèn)值
泛型的默認(rèn)值,如下面代碼所示。需要使用default(T)來賦值。
不管泛型到底是String,int,bool或者是一個(gè)Class類型,都可以被自動(dòng)賦值。
public static void Excute() { Generic<int> gs = new Generic<int>(); gs.Name = 518; Generic<Task> gsTask = new Generic<Task>(); gsTask.Name = new Task(()=> { Console.WriteLine("Kiba518"); }); } public class Generic<T> { public T Name = default(T); }
泛型的約束
在泛型類中,有個(gè)特別的約束可供我們使用。
當(dāng)我們不顯示的聲明時(shí),這個(gè)約束不存在。但當(dāng)我們顯示的聲明的時(shí)候,這個(gè)約束就會(huì)執(zhí)行。
下面,我們來看看這個(gè)特別的約束。
public static void Excute() { Generic<FanXing> gFanXing = new Generic<FanXing>(); Generic< > gFanXing = new Generic< >(); //Generic<string> gs = new Generic<string>(); 這樣定義會(huì)報(bào)錯(cuò) } public class Generic<T> where T : { public T Name = default(T); } public class { public string Name { get; set; } } public class FanXing : { public new string Name { get; set; } }
如上面代碼所示,【where T : 】就是這個(gè)特別的約束。
當(dāng)顯示聲明這個(gè)約束的時(shí)候,定義會(huì)限制泛型的類型。
什么是限制泛型的類型呢?
很簡單,泛型T,是泛指某一個(gè)類型。我們?cè)诙x泛型類時(shí),還需顯示的指定類型,此時(shí)我們顯示指定的類型,要受這個(gè)限制。
這個(gè)限制就是指【where T : 】。
它的限制是,要求我們指定的類型T必須是 ,或者該類型繼承自 ,如FanXing類。
泛型的函數(shù)
在C#中,泛型不僅可以用于類,還可以直接用于函數(shù)。
具體使用方式如下:
public static void Excute() { GenericFunc gf = new GenericFunc(); gf.FanXingFunc<FanXing>(new FanXing() { Name="Kiba518"}); } public class GenericFunc { public void FanXingFunc<T>(T obj) { Console.WriteLine(obj.GetType()); } }
很簡單,調(diào)用泛型函數(shù)的時(shí)候,指定泛型函數(shù)的[指定類型]即可。
但是,這里我們發(fā)現(xiàn)一個(gè)問題,那就是,在泛型函數(shù)里,使用泛型對(duì)象的時(shí)候,我們發(fā)現(xiàn)對(duì)象都是 類型的。
那我們?nèi)绻胧褂梅盒蛯?duì)象里的屬性和方法時(shí),要怎么辦呢?
也很簡單,反射就可以了。
下面我們添加一個(gè)反射函數(shù)GetPropertyValue,專門用來獲取屬性。
public class GenericFunc { public void FanXingFunc<T>(T obj) { var name = GetPropertyValue(obj, "Name"); Console.WriteLine(name); } public GetPropertyValue( obj, string name) { drv1 = obj.GetType().GetProperty(name).GetValue(obj, null); return drv1; } }
輸出結(jié)果如下:
這樣我們就得到了我們想要的結(jié)果,如果想使用泛型類里的函數(shù),道理也一樣,只需要用反射來調(diào)用即可。
結(jié)語
看到這里,有些同學(xué)可能會(huì)覺得泛型很復(fù)雜,連使用其對(duì)象下的屬性,都得反射,太繁瑣了,還不如不用呢。
有這樣想法的同學(xué),心里想想就好了,如果對(duì)老司機(jī)這么說,他肯定會(huì)內(nèi)心默默的微笑,然后對(duì)你說,你想的沒錯(cuò)。
然后,你就沒有然后了。
泛型的應(yīng)用,開篇已經(jīng)說了,主要用在提高代碼的可重用性、類型安全性和效率上。
如果只是定義一個(gè)類,調(diào)用一個(gè)屬性,那泛型的存在就是雞肋。
但事實(shí)上,我們的系統(tǒng)永遠(yuǎn)只有更復(fù)雜,更復(fù)雜,更復(fù)雜。因此泛型才有了用武之地。
----------------------------------------------------------------------------------------------------
注:此文章為原創(chuàng),歡迎轉(zhuǎn)載,請(qǐng)?jiān)谖恼马撁婷黠@位置給出此文鏈接!
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。