c#2.0泛型學習(一)

來源:互聯網
上載者:User

根據微軟的視頻教程"跟我一起學Visual Studio 2005C#文法篇"來學,因為裡面有比較多的程式碼範例,學起來比較容易好理解

1.未使用泛型的Stack類

 1using System;
 2
 3public class Stack
 4{
 5    readonly int m_Size;
 6    int m_StackPointer = 0;
 7    object[] m_Items;
 8    public Stack(): this(100)
 9    { }
10    public Stack(int size)
11    {
12        m_Size = size;
13        m_Items = new object[m_Size];
14    }
15    public void Push(object item)
16    {
17        if (m_StackPointer >= m_Size)
18            throw new StackOverflowException();
19
20        m_Items[m_StackPointer] = item;
21        m_StackPointer++;
22    }
23    public object Pop()
24    {
25        m_StackPointer--;
26        if (m_StackPointer >= 0)
27        {
28            return m_Items[m_StackPointer];
29        }
30        else
31        {
32            m_StackPointer = 0;
33            throw new InvalidOperationException("Cannot pop an empty stack");
34        }
35    }
36}
37
2.使用泛型的類

 1using System;
 2
 3public class Stack<T>
 4{
 5    readonly int m_Size;
 6    int m_StackPointer = 0;
 7    T[] m_Items;
 8    public Stack()
 9        : this(100)
10    {
11    }
12    public Stack(int size)
13    {
14        m_Size = size;
15        m_Items = new T[m_Size];
16    }
17    public void Push(T item)
18    {
19        if (m_StackPointer >= m_Size)
20            throw new StackOverflowException();
21
22        m_Items[m_StackPointer] = item;
23        m_StackPointer++;
24    }
25    public T Pop()
26    {
27        m_StackPointer--;
28        if (m_StackPointer >= 0)
29        {
30            return m_Items[m_StackPointer];
31        }
32        else
33        {
34            m_StackPointer = 0;
35            //throw new InvalidOperationException("Cannot pop an empty stack");
36            return default(T);
37        }
38    }
39}
40
41public class Stack1<T> : Stack<T>
42{
43
44}
45
下為PDF文檔,我感覺挺好的,很簡單,我聽的懂就是好的
/Clingingboy/one.pdf

多個泛型
 1class Node<K, T>
 2{
 3    public K Key;
 4    public T Item;
 5    public Node<K, T> NextNode;
 6    public Node()
 7    {
 8        Key = default(K);
 9        Item = default(T);
10        NextNode = null;
11    }
12    public Node(K key, T item, Node<K, T> nextNode)
13    {
14        Key = key;
15        Item = item;
16        NextNode = nextNode;
17    }
18}
泛型別名

1using list = LinkedList<int, string>;
泛型約束

 1public class LinkedList<K, T> where K : IComparable
 2{
 3    Node<K, T> m_Head;
 4    public LinkedList()
 5    {
 6        m_Head = new Node<K, T>();
 7    }
 8    public void AddHead(K key, T item)
 9    {
10        Node<K, T> newNode = new Node<K, T>(key, item, m_Head.NextNode);
11        m_Head.NextNode = newNode;
12    }
13
14    T Find(K key)
15    {
16        Node<K, T> current = m_Head;
17        while (current.NextNode != null)
18        {
19            if (current.Key.CompareTo(key) == 0)
20                break;
21            else
22                current = current.NextNode;
23        }
24        return current.Item;
25    }
26
27}
28

 1using System;
 2using System.Collections.Generic;
 3using System.Text;
 4
 5namespace VS2005Demo1
 6{
 7    public class MyBaseClassGeneric // sealed,static
 8    {
 9    }
10
11    interface IMyBaseInterface
12    {
13        void A();
14    }
15
16    internal class GenericClass<T> where T : MyBaseClassGeneric,IMyBaseInterface
17    {
18   
19    }
20
21    class GClass<K, T> where K : MyBaseClassGeneric,IMyBaseInterface,new() where T : K
22    {
23   
24    }
25
26    class GUClass<K, T> where T : K where K : MyBaseClassGeneric,IMyBaseInterface, new()
27    {
28        GClass<K, T> obj = new GClass<K, T>();
29    }
30
31
32    不能將引用/實值型別約束與基類約束一起使用,因為基類約束涉及到類#region 不能將引用/實值型別約束與基類約束一起使用,因為基類約束涉及到類
33   
34    //class A<T> where T : struct,class
35    //{}
36   
37    #endregion
38
39    不能使用結構和預設建構函式約束,因為預設建構函式約束也涉及到類#region 不能使用結構和預設建構函式約束,因為預設建構函式約束也涉及到類
40
41    //class A<T> where T : struct,new()
42    //{}
43
44    #endregion
45
46    雖然您可以使用類和預設建構函式約束,但這樣做沒有任何價值#region 雖然您可以使用類和預設建構函式約束,但這樣做沒有任何價值
47
48    class A<T> where T : new()
49    {
50        T obj = new T();
51    }
52
53    class TypeA
54    {
55        public TypeA() { }
56    }
57
58    class TestA
59    {
60        A<TypeA> obj = new A<TypeA>();
61    }
62
63    #endregion
64
65    可以將引用/實值型別約束與介面約束組合起來,前提是引用/實值型別約束出現在約束列表的開頭#region 可以 將引用/實值型別約束與介面約束組合起來,前提是引用/實值型別約束出現在約束列表的開頭
66   
67    class SClass<K> where K : struct, IMyBaseInterface
68    { }
69
70    class CClass<K> where K : class, IMyBaseInterface
71    { }
72   
73    #endregion
74}
75

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.