zoukankan      html  css  js  c++  java
  • C#构建数据类型不同的链表

    一、c#构造链表,此链表只能接受相同的数据类型,因为m_data字段使用了相同类型:

    internal class Node<T>
        {
            public T m_data;
            public Node<T> m_next;
    
            public Node(T data) : this(data, null)
            {
            }
    
            public Node(T data, Node<T> next)
            {
                m_data = data;
                m_next = next;
            }
    
            public override string ToString()
            {
                return m_data.ToString() + ((m_next != null) ? m_next.ToString() : string.Empty);
            }
        }

    二、使用object类型构造链表可以传入不同的类型,但是会丧失编译时类型安全性,且传值类型时会有装箱的性能问题,所以使用非泛型基类+泛型子类是个更好的方法:

    internal class Node
        {
            public Node m_next;
    
            public Node(Node next)
            {
                m_next = next;
            }
        }
    
        internal sealed class TypeNode<T> : Node
        {
            public T m_data;
    
            public TypeNode(T data) : this(data, null)
            {
            }
    
            public TypeNode(T data, Node next) : base(next)
            {
                m_data = data;
            }
    
            static TypeNode()
            {//静态构造方法会在每次传入具体类型时,执行一次,可以用来约束泛型,比如:枚举
                if (typeof(T) == typeof(object))
                {
                    throw new ArgumentException("Do not use object type!");
                }
            }
    
            public override string ToString()
            {
                return m_data.ToString() + ((m_next != null) ? m_next.ToString() : string.Empty);
            }
        }

    调用:

    private static void Main(string[] args)
            {
                Node head = new TypeNode<char>('-');
                head = new TypeNode<DateTime>(DateTime.Now, head);
                head = new TypeNode<int>(20, head);
                head = new TypeNode<object>(55, head);//报错
                Console.WriteLine(head);
                Console.ReadKey();
            }
  • 相关阅读:
    Directx 3D编程实例:多个3D球的综合Directx实例
    利用组策略禁用Oultook 各个版本的缓存模式!
    node-mongo-native1.3.19连接mongo的最优方法
    BT5之网络配置
    BT5之配置笔记
    Linux常用命令大全
    Linux下的基本网络配置
    SQLMAP系列教程
    重燃你的PHP安全分析之火
    Metasploit渗透测试魔鬼训练营
  • 原文地址:https://www.cnblogs.com/Zdelta/p/14122311.html
Copyright © 2011-2022 走看看