如何理解.NET基礎的自定義泛型-創(chuàng)新互聯(lián)

這篇文章主要介紹“如何理解.NET基礎的自定義泛型”,在日常操作中,相信很多人在如何理解.NET基礎的自定義泛型問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何理解.NET基礎的自定義泛型”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,劍閣企業(yè)網(wǎng)站建設,劍閣品牌網(wǎng)站建設,網(wǎng)站定制,劍閣網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,劍閣網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

具體分析如下:

在.NET中泛型使用非常頻繁,在控制臺應用程序中,默認的引入了System.Collection.Generics名稱空間,其中就提供了我們經(jīng)常使用的泛型:List<T>和Dictionary<T>,相信用過它們的都知道它們的強大。還有一種我們經(jīng)常使用的簡單的泛型:System.Nullable<T>,即可空類型。我們可以:
 
System.Nullable<int> nullableInt;
聲明一個可空的int類型,由于C#語法對這個做了簡化通常我們都不這樣寫,而是這樣寫:
 
int? nullableInt
下面重點介紹一下如何自定義泛型。
 
定義泛型類
 
創(chuàng)建泛型類是需要在類定義中用尖括號語法:


復制代碼 代碼如下:

class MyGenericClass<T>
{
    ...
}


T可以是任意的標示符,只要遵守命名規(guī)則即可。

可以把類型用在類成員的返回類型,方法參數(shù)類型等,例如:


復制代碼 代碼如下:

class MyGenericClass<T1, T2, T3>
{
    private T1 t1Object;
 
    public MyGenericClass(T1 item)
    {
        t1Object = item;
    }
 
    public T1 T1Object
    {
        get
        {
            return t1Object;
        }
    }
}

注意如果不能假定提供了什么類型。下面的代碼不能執(zhí)行:


復制代碼 代碼如下:

class MyGenericClass<T1, T2, T3>
{
    private T1 t1Object;
 
    public MyGenericClass()
    {
        t1Object = new T1();
    }
}

因為我們不知道T1是否有公有的默認構造函數(shù)。

default關鍵字
 
如果我們定義了一個泛型的字段,我們想在構造函數(shù)中初始化它,但是我們不知道它的引用類型還是值類型,那么default就派上用處了:


復制代碼 代碼如下:

public MyGenericClass()
{
    t1Object = default(T1);
}


如果是值類型就賦值0,引用類型就賦值null。

約束類型
 
在定義泛型的時候我們可以對類型進行約束,通過where關鍵字實現(xiàn):


復制代碼 代碼如下:

class MyGenericClass<T1> where T : constraint1,constraint
{
    ...
}


constraint定義了約束,多個約束用逗號隔開,如果有多個類型:


復制代碼 代碼如下:

class MyGenericClass<T1, T2> where T1 : constraint1 where T2 : constraint
{
    ...
}


下面給出一些可用的約束
 
                                        約束                                                                  說明
 
                                where T:struct                                     使用結構約束,類型T必須是值類型
 
                                where T:calss                                       類約束指定,類型T必須是引用類型
 
                                where T:interface                                  指定類型T必須實現(xiàn)是接口或者實現(xiàn)了接口
 
                                where T:base-class                               指定類型T必須是基類或者派生于基類
 
                               where T:new()                                       指定類型T必須有一個默認構造函數(shù)
 
 
 
下面結合以上知識給個實例:(PS不要看到代碼多 其實很簡單的 耐心看下去)
 
先定義四個類Animal、Cow 、Chicken和SuperCow


復制代碼 代碼如下:

#region Animal 虛基類 有一個name屬性 Feed方法和一個虛方法MakeANoise
//虛基類 有一個name屬性 Feed方法和一個虛方法MakeANoise
public abstract class Animal
{
        protected string name;
 
        public string Name
        {
            get
            {
                return name;
            }
            set
            {
                name = value;
            }
        }
 
        public Animal()
        {
            name = "The animal with no name";
        }
 
        public Animal(string newName)
        {
            name = newName;
        }
 
        public void Feed()
        {
            Console.WriteLine("{0} has been fed.", name);
        }
 
        public abstract void MakeANoise();
}
#endregion

//Cow Animal的子類,實現(xiàn)虛方法
public class Cow:Animal
{
        public Cow(string name) :
            base(name)
        {
        }
        public override void MakeANoise()
        {
            Console.WriteLine("{0} says 'moo!'", name);
        }
}

//Chicken類,Animal子類
public class Chicken:Animal
{
        public Chicken(string name)
            : base(name)
        { }
        public override void MakeANoise()
        {
            Console.WriteLine("{0} says 'cluck'", name);
        }
}

//Cow的子類,有一個自己的方法Fly
class SuperCow : Cow
{
        public SuperCow(string name) : base(name)
        {
        }
 
        public void Fly()
        {
            Console.WriteLine("{0} is flying!", name);
        }
 
        public override void MakeANoise()
        {
            Console.WriteLine("{0} says 'I am supercow!'", name);
        }
}

類準備好了之后,我們可以開始定義我們的泛型了:


復制代碼 代碼如下:

//繼承了迭代器接口,這樣方便使用Foreach 約束它的類型為Animal及其子類
public class Farm<T>:IEnumerable<T> where T : Animal
{
        private List<T> animals = new List<T>();
 
        public List<T> Animals
        {
            get
            {
                return animals;   
            }
        }
        //迭代器
        public IEnumerator<T> GetEnumerator()
        {
            return animals.GetEnumerator();
        }
 
        IEnumerator IEnumerable.GetEnumerator()
        {
            return animals.GetEnumerator();
        }
 
        //執(zhí)行所有animal的MakeANoise()
        public void MakeNoises()
        {
            foreach (T animal in animals)
            {
                animal.MakeANoise();
            }
        }
        //執(zhí)行所有animal的Feed()
        public void FeedTheAnimals()
        {
            foreach (T animal in animals)
            {
                animal.Feed();
            }
        }
        //獲得animals中的cow
        public Farm<Cow> GetCows()
        {
            Farm<Cow> cowFarm = new Farm<Cow>();
            foreach (T animal in animals)
            {
                if (animal is Cow)
                {
                    cowFarm.Animals.Add(animal as Cow);
                }
            }
            return cowFarm;
        }
}

泛型定義好了,我們用寫代碼來調(diào)用它:


復制代碼 代碼如下:

class Program
{
        static void Main(string[] args)
        {
            Farm<Animal> farm = new Farm<Animal>();
            farm.Animals.Add(new Cow("Jack"));
            farm.Animals.Add(new Chicken("Vera"));
            farm.Animals.Add(new Chicken("Sally"));
            farm.Animals.Add(new SuperCow("Kevin"));
            farm.MakeNoises();
 
            Farm<Cow> dairyFarm = farm.GetCows();
            dairyFarm.FeedTheAnimals();
 
            foreach (Cow cow in dairyFarm)
            {
                if (cow is SuperCow)
                {
                    (cow as SuperCow).Fly();
                }
            }
            Console.ReadKey();
        }
}

到此,關于“如何理解.NET基礎的自定義泛型”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

分享文章:如何理解.NET基礎的自定義泛型-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://muchs.cn/article36/dcgppg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、微信小程序、外貿(mào)網(wǎng)站建設、網(wǎng)站排名用戶體驗、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作