澳门至尊网站-首页

您的位置:澳门至尊网站 > 软件综合 > 泛型约束实际采纳

泛型约束实际采纳

2019-10-22 21:29

前言

所谓泛型,即经过参数化类型来完结在相似份代码上操作多样数据类型。

泛型编制程序是后生可畏种编制程序范式,它选择“参数化类型”将品种抽象化,进而达成更为灵活的复用。在概念泛型类时,在对客商端代码可以在实例化类时,能够用项目参数的品类类别施加节制。在搭建底层框架时,是最分布的编制程序方式。

 

泛型类

泛型类范例:

namespace ORDER.SYSTEM.DAL.Data
{
    public abstract class AgentBase<T> where T : class, new()
    {

        //私有实例
        private static T _instance;

        // 定义一个标识确保线程同步
        private static readonly object locker = new object();

        /// <summary>
        /// 返回单例对象
        /// </summary>
        /// <returns></returns>
        public static T Instance()
        {
            if (_instance == null)
            {
                lock (locker)
                {
                    if (_instance == null)
                    {
                        switch (typeof(T).FullName)
                        {
                            case "ORDER.SYSTEM.BLL.TextImpl":
                                _instance = new T(); //此处的T表示命名空间的下的某个类被托管或重写,只保留功能
                                break;
                            default:
                                _instance = new T();
                                break;
                        }
                    }
                }
            }
            return _instance;
        }

    }
}

泛型类的指标是为了约束泛型方法传参数类型或回到值类型。

 

泛型方法

在C# 2.0中,方法能够定义特定于其施行范围的泛型参数,如下所示:

public class MyClass<T>
{
    //指定MyMethod方法用以执行类型为X的参数
    public void MyMethod<X>(X x) 
    {
        //
    }

    //此方法也可不指定方法参数
    public void MyMethod<X>() 
    {
        //
    }
}   

哪怕带有类不适用泛型参数,你也足以定义方法特定的泛型参数,如下所示:

public class MyClass
{
    //指定MyMethod方法用以执行类型为X的参数
    public void MyMethod<X>(X x) 
    {
        //
    }

    //此方法也可不指定方法参数
    public void MyMethod<X>() 
    {
        //
    }
}

注意:质量和索引器不可能钦命本人的泛型参数,它们只可以采取所属类中定义的泛型参数实行操作。

在调用泛型方法的时候,你能够提供要在调用场面选择的类别,如下所示:

//调用泛型方法
MyClass myClass = new MyClass();
myClass.MyMethod<int>(3);

 

泛型推理:

在调用泛型方法时,C#编写翻译器丰硕聪明,基于传入的参数类型来揣摸出科学的品类,而且它同意完全市略类型标准,如下所示:

//泛型推理机制调用泛型方法
MyClass myClass = new MyClass();
myClass.MyMethod(3);

小心:泛型方法不可能只依照再次回到值的等级次序估摸出类型,代码如下:

public GenericMethodDemo()
{        
    MyClass myClass = new MyClass();
    /****************************************************
    无法从用法中推理出方法“GenericMethodDemo.MyClass.MyMethod<T>()”的类型参数。
    请尝试显式指定类型参数。
    ***************************************************/
    int number = myClass.MyMethod();
}

public class MyClass
{
    public T MyMethod<T>() 
    {
        //
    }
}

泛型方法中泛型参数的牢笼,如下:

public class MyClass
{

    public void MyMethod<X>(X x) where X:IComparable<X>
    {
        //
    }
}

 

.NET泛型限制

假诺顾客端代码尝试采纳某些约束所不允许的种类来实例化类,则会生出编写翻译时不当。那些约束称为约束。限制是应用 where 上下文关键字钦定的。

下表列出了各类档期的顺序的牢笼:

 

约束 说明

T:struct

类型参数必须是值类型。可以指定除 Nullable 以外的任何值类型。

T:class

类型参数必须是引用类型,包括任何类、接口、委托或数组类型。

T:new()

类型参数必须具有无参数的公共构造函数。当与其他约束一起使用时,new() 约束必须最后指定。

T:<基类名>

类型参数必须是指定的基类或派生自指定的基类。

T:<接口名称>

类型参数必须是指定的接口或实现指定的接口。可以指定多个接口约束。约束接口也可以是泛型的。

T:U

为 T 提供的类型参数必须是为 U 提供的参数或派生自为 U 提供的参数。这称为裸类型约束.

 

 

 

派生节制

1.常见的

public class MyClass5 where T :IComparable { }

2.羁绊放在类的实在派生之后

public class B { }

public class MyClass6 : B where T : IComparable { }

3.得以继续三个基类和多少个接口,且基类在接口前边

public class B { }

public class MyClass7 where T : B, IComparable, ICloneable { }

 

构造函数限制

1.常见的

public class MyClass8 where T : new() { }

2.方可将构造函数限制和派生约束组合起来,前提是构造函数约束出现在封锁列表的末梢

public class MyClass8 where T : IComparable, new() { }

 

值约束

1.常见的

public class MyClass9 where T : struct { }

2.与接口约束同期使用,在最前边(不可能与基类节制,构造函数限定共同利用)

public class MyClass11 where T : struct, IComparable { }

 

援引限制

常见的

public class MyClass10 where T : class { }

四个泛型参数

public class MyClass12<T, U> where T : IComparable where U : class { }

 

 

PS:应接扫描下方二维码,出席QQ群

图片 1

 

作者:Jacky

来源:

宣示:本文版权归小编和新浪共有,应接转载,但未经作者同意务必保留此段注解,且在篇章页面显然地点给出原来的作品连接,不然保留追究法律义务的义务。

本文由澳门至尊网站发布于软件综合,转载请注明出处:泛型约束实际采纳

关键词: