zoukankan      html  css  js  c++  java
  • 泛型的详细解释与示例

      using System;

      using System.Collections.Generic;

      using System.Text;

      namespace Generic

      {

      /// <summary>

      /// 泛型是具有占位符(类型参数)的类、结构、接口和方法,这些占位符是类、结构、接口和方法所存储或使用的一个或多个类型的占位符。泛型集合类可以将类型参数用作它所存储的对象的类型的占位符;类型参数作为其字段的类型和其方法的参数类型出现。泛型方法可以将其类型参数用作其返回值的类型或者其形参的类型之一。

      /// </summary>

      /// <typeparam name="T"></typeparam>

      ///在创建泛型类的实例时,会指定实际类型来替换类型参数。这会建立一个新的泛型类,称为构造泛型类,选定的类型将替换所有出现的类型参数。最后得到按照您选择的类型定制的类型安全的类,如下面的代码所示。

      /*

      Generic<string> g = new Generic<string>();

      g.Field = "A string";

      */

      /*“泛型类型定义”是用作模板的类、结构或接口声明,其中具有该类、结构或接口声明可以包含或使用的类型的占位符。例如,Dictionary 类可以包含两种类型:键和值。因为它只是一个模板,您不能创建作为泛型类型定义的类、结构或接口的实例。

      “泛型类型参数”或称“类型参数”是泛型类型或方法定义中的占位符。Dictionary 泛型类型具有两个类型参数:TKey 和 TValue,分别表示其键和值的类型。

      “构造泛型类型”或称“构造类型”是为泛型类型定义的泛型类型参数指定类型得到的结果。

      “泛型类型参数”是替换泛型类型参数的任何类型。

      一般术语“泛型类型”包括构造类型和泛型类型定义。

      “约束”是加在泛型类型参数上的限制。例如,可以将类型参数限制为实现 IComparer 泛型接口的类型以确保可以对该类型的实例进行排序。还可以将类型参数限制为具有特定基类的类型、具有默认构造函数的类型或是引用类型或值类型。泛型类型的用户不能替换不满足这些约束的类型参数。

      “泛型方法定义”是具有两个参数列表的方法:一个泛型类型参数列表和一个形参列表。类型参数可以作为返回类型或形参的类型出现,如下面的代码所示。

      */

      /*泛型方法可以出现在泛型或非泛型类型上。需要注意的是,并不是只要方法属于泛型类型,或者甚至是方法的形参的类型是封闭类型的泛型参数,就可以说方法是泛型方法。只有当方法具有它自己的类型参数列表时,才能称其为泛型方法。在下面的代码中,只有方法 G 是泛型方法。

      class A

      {

      T G<T>(T arg) {…}

      }

      class Generic<T>

      {

      T M(T arg) {…}

      }

      */

      public class GenericList<T>

      {

      /*嵌套类型和泛型

      嵌套于泛型类型中的类型依赖于封闭泛型类型的类型参数,广州达内C++公共语言运行库将这样的嵌套类型视为泛型,即使它们没有自己的泛型类型参数。在创建嵌套类型的实例时,需要为所有封闭泛型类型指定类型参数。

      */

      // Node类也是泛型的

      private class Node

      {

      // 非泛型的构造函数

      public Node(T t)

      {

      next = null;

      data = t;

      }

      private Node next;

      public Node Next

      {

      get { return next; }

      set { next = value; }

      }

      // T 定义私有成员

      private T data;

      // T 属性

      public T Data

      {

      get { return data; }

      set { data = value; }

      }

      }

      private Node head;

      // GenericList的构造函数

      public GenericList()

      {

      head = null;

      }

      // 参数是T类型的:

      public void AddHead(T t)

      {

      Node n = new Node(t);

      n.Next = head;

      head = n;

      }

      public IEnumerator<T> GetEnumerator()

      {

      Node current = head;

      while (current != null)

      {

      yield return current.Data;

      current = current.Next;

      }

      }

      }

      class Program

      {

      static void Main(string[] args)

      {

      // 声明类型是int

      GenericList<int> list = new GenericList<int>();

      for (int x = 0; x < 10; x++)

      {

      list.AddHead(x);

      }

      foreach (int i in list)

      {

      System.Console.Write(i + " ");

      }

      System.Console.WriteLine("\nDone");

      Console.Read();

      }

      }

      }

  • 相关阅读:
    The XOR Largest Pair
    似乎在梦中见过的样子 (KMP)
    Censoring(栈+KMP)
    KMP解决最小循环节问题
    收集雪花 (贪心+双指针+离散化)
    「POI2010」反对称 Antisymmetry (manacher算法)
    A Horrible Poem (字符串hash+数论)
    leetcode103——二叉树的锯齿形层次遍历
    leetcode102 ——二叉树的层序遍历
    二叉树——100 相同的树(easy)
  • 原文地址:https://www.cnblogs.com/javaitpx/p/2788982.html
Copyright © 2011-2022 走看看