博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
个彻底解释 C#泛型的源代码
阅读量:6705 次
发布时间:2019-06-25

本文共 2799 字,大约阅读时间需要 9 分钟。

using System;

using System.Collections.Generic;
using System.Text;

namespace Iinterface

{
    //声明T类型.
    public class GenericList<T> : System.Collections.Generic.IEnumerable<T>
    {
        protected Node head;
        protected Node current = null;

        // 定义一个Node类,该类也是泛型类型

        protected class Node
        {
            public Node next;
            //T类型的成员
            private T data;

            //构造函数不是泛型类型,参数类型应用了T类型

            public Node(T t)
            {
                next = null;
                data = t;
            }

            public Node Next

            {
                get { return next; }
                set { next = value; }
            }

            //属性的返回类型是T类型

            public T Data
            {
                get { return data; }
                set { data = value; }
            }
        }

        //构造函数

        public GenericList()
        {
            head = null;
        }

        //增加元素

        public void AddHead(T t)
        {
            Node n = new Node(t);
            n.Next = head;
            head = n;
        }

        // 迭代

        public System.Collections.Generic.IEnumerator<T> GetEnumerator()
        {
            Node current = head;
            while (current != null)
            {
                yield return current.Data;
                current = current.Next;
            }
        }

        System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()

        {
            return GetEnumerator();
        }
    }

    /// <summary>
    /// 排序
    /// where 子句用于指定类型约束,这些约束可以作为泛型声明中定义的类型参数的变量
    /// </summary>
    /// <typeparam name="T"></typeparam>
    public class SortedList<T> : GenericList<T> where T : System.IComparable<T>
    {
        // 约束条件
        //冒泡排序
        public void BubbleSort()
        {
            if (null == head || null == head.Next)
            {
                return;
            }
            bool swapped;

            do

            {
                Node previous = null;
                Node current = head;
                swapped = false;

                while (current.next != null)

                {
                    if (current.Data.CompareTo(current.next.Data) > 0)
                    {
                        Node tmp = current.next;
                        current.next = current.next.next;
                        tmp.next = current;

                        if (previous == null)

                        {
                            head = tmp;
                        }
                        else
                        {
                            previous.next = tmp;
                        }
                        previous = tmp;
                        swapped = true;
                    }
                    else
                    {
                        previous = current;
                        current = current.next;
                    }
                }
            } while (swapped);
        }
    }

   
  
    // 使用IComparable<T>.
    public class Person : System.IComparable<Person>
    {
        string name;
        int age;

        public Person(string s, int i)

        {
            name = s;
            age = i;
        }

        // 实现按照Age排序.

        public int CompareTo(Person p)
        {
            return age - p.age;
        }

        public override string ToString()

        {
            return name + ":" + age;
        }

        // 必须实现Equals操作.

        public bool Equals(Person p)
        {
            return (this.age == p.age);
        }
    }

    /// <summary>
    /// 主函数
    /// </summary>
    class Program
    {
        static void Main(string[] args)
        {
            //声明一个新的泛型对象.
            //Person是类型参数.
            SortedList<Person> list = new SortedList<Person>();

            //创建一个Person对象的成员.

            string[] names = new string[]
        {
            "王五",
            "赵燕",
            "李毅",
            "马龙",
            "斯托克顿",
            "克林顿",
            "马晓旭",
            "张望",
            "林炳",
            "钱龙"
        };

            int[] ages = new int[] { 45, 19, 28, 23, 18, 9, 108, 72, 30, 35 };

            //填入成员.

            for (int x = 0; x < 10; x++)
            {
                list.AddHead(new Person(names[x], ages[x]));
            }

            //打印没有排序的成员.

            foreach (Person p in list)
            {
                System.Console.WriteLine(p.ToString());
            }
            System.Console.WriteLine("还没有排序呢!\n");

            //排序.

            list.BubbleSort();

            //打印排序后的成员.

            foreach (Person p in list)
            {
                System.Console.WriteLine(p.ToString());
            }

            System.Console.WriteLine("排序完成啦!");

            Console.Read();

        }
    }
}

转载于:https://www.cnblogs.com/javaitpx/archive/2012/11/23/2784130.html

你可能感兴趣的文章
Linux下如何定制SSH来简化远程访问
查看>>
空与非空 EMPTY_LOB和NULL的区别
查看>>
未来的主角是公有云还是私有云?哪些云安全企业能在行业洗牌中脱颖而出
查看>>
可能吞噬硬件的无服务器云
查看>>
如何自行搭建一个威胁感知大脑 SIEM?| 硬创公开课
查看>>
安全圈老司机为什么会在这个游戏里翻车?(内附详细解谜攻略)
查看>>
大数据将带来哪些“健康红利”?
查看>>
技术派的梦想旅行,用大数据推动旅游2.0时代到来
查看>>
高校 WiFi 9 大谬论
查看>>
CyrusOne计划在美国德克萨斯建设大型数据中心园区
查看>>
暴风热点 要的不仅仅是免费WIFI
查看>>
MSR路由器的未来之路
查看>>
《C语言程序设计:问题与求解方法》——3.10节提高部分
查看>>
《数据库基础及实践技术——SQL Server 2008》一3.3 查看和设置数据库选项
查看>>
边缘计算将蚕食云计算,可能吗?
查看>>
别折腾安全软件了 你的手机也许还不配被黑客破解
查看>>
工信部:推动窄带物联网、5G泛在信息基础设施
查看>>
腾商助政和供电将月例会变成日常工作交流
查看>>
对于HIPAA合规来说,安全差距分析重要吗?
查看>>
集成电路产业的未来握在谁手中?
查看>>