zoukankan      html  css  js  c++  java
  • C#如何创建泛型类T的实例

    最近在学历基类的写法时,遇到了一个问题:如何怎么创建一个泛型类T的实例呢?    

    废话不多说了,直接上代码吧,目前发现三种方法,先贴上,以后再总结,希望能帮助跟我遇到同样问题的朋友。

    方法一,通过外部方法传入的实例来实例化:

    //泛型类:
    public class MySQLHelp<T>
    {
           private T t;
           public MySQLHelp(T t)
            {
                this.t = t;
            }    
    }
    
    //测试类
    public class Test{
         public static void Main(){
                   MySQLHelp<Message> mm = new MySQLHelp<Message>(new Message());
         }
    }
    //其他类
    public class Message{
    
    }

    方法二,通过限制泛型类的构造函数:

        限制泛型类必须带有无参构造方法:public class MySQLHelp<T> where T:new()

    //泛型类:
    public class MySQLHelp<T> where T:new()
    {
           private T t=new T();
           public MySQLHelp()
            {
            }    
    }
    
    //测试类
    public class Test{
         public static void Main(){
                   MySQLHelp<Message> mm = new MySQLHelp<Message>();
         }
    }
    //其他类
    public class Message{
    
    }

    方法三,利用微软提供的方法:

       利用微软的类:System.Activator(包含创建本地或远程对象类型的方法或获取引用的方法,翻译名:活化剂类)

    创建指定泛型类型参数指定的类型的实例:System.Activator.CreateInstance<T>()
    //泛型类:
    public class MySQLHelp<T>
    {
           //创建指定泛型类型参数指定的类型的实例(使用这种方法可以不对泛型类型T做限制,即不用添加:where T:new())
            private T t = System.Activator.CreateInstance<T>();
           public MySQLHelp()
            {
            }    
    }
    
    //测试类
    public class Test{
         public static void Main(){
                   MySQLHelp<Message> mm = new MySQLHelp<Message>();
         }
    }
    //其他类
    public class Message{
    
    }
  • 相关阅读:
    图解HTTPS
    JQuery 控件
    sql server 中某个字段值合并【转】
    ASP.NET时间函数及其格式转换
    数据库 'tempdb' 的日志已满
    @@ERROR 和 @@ROWCOUNT
    SQL Server中行列转换 Pivot UnPivot 【转】
    Global.asax详解
    SQL Server 2008时提示评估期已过的解决办法
    C# IO读取文件问题:正由另一进程使用
  • 原文地址:https://www.cnblogs.com/lxhbky/p/6020612.html
Copyright © 2011-2022 走看看