泛型类型参数(C# 编程指南)

在泛型类型或方法定义中,类型参数是客户端在实例化泛型类型的变量时指定的特定类型的占位符。泛型类(如 泛型介绍(C# 编程指南) 中列出的 GenericList<T>)不可以像这样使用,因为它实际上并不是一个类型,而更像是一个类型的蓝图。若要使用 GenericList<T>,客户端代码必须通过指定尖括号中的类型参数来声明和实例化构造类型。此特定类的类型参数可以是编译器识别的任何类型。可以创建任意数目的构造类型实例,每个实例使用不同的类型参数,如下所示:

GenericList<float> list1 = new GenericList<float>();
GenericList<ExampleClass> list2 = new GenericList<ExampleClass>();
GenericList<ExampleStruct> list3 = new GenericList<ExampleStruct>();

在每个 GenericList<T> 实例中,类中出现的每个 T 都会在运行时替换为相应的类型参数。通过这种替换方式,我们使用一个类定义创建了三个独立的类型安全的有效对象。有关 CLR 如何执行此替换的更多信息,请参见运行时中的泛型(C# 编程指南)

类型参数命名准则

  • 务必使用描述性名称命名泛型类型参数,除非单个字母名称完全可以让人了解它表示的含义,而描述性名称不会有更多的意义。

    public interface ISessionChannel&lt;TSession&gt; { /*...*/ }
    public delegate TOutput Converter&lt;TInput, TOutput&gt;(TInput from);
    public class List&lt;T&gt; { /*...*/ }
    
  • 考虑使用 T 作为具有单个字母类型参数的类型的类型参数名。

    public int IComparer&lt;T&gt;() { return 0; }
    public delegate bool Predicate&lt;T&gt;(T item);
    public struct Nullable&lt;T&gt; where T : struct { /*...*/ }
    
  • 务必将“T”作为描述性类型参数名的前缀。

    public interface ISessionChannel&lt;TSession&gt;
    {
        TSession Session { get; }
    }
    
  • 考虑在参数名中指示对此类型参数的约束。例如,可以将带有 ISession 约束的参数命名为 TSession。

请参阅

System.Collections.Generic

C# 编程指南

泛型(C# 编程指南)

C++ 模板和 C# 泛型之间的区别(C# 编程指南)