时间:2021-05-20
本文实例分析了C#泛型用法。分享给大家供大家参考。具体分析如下:
这里演示如何创建具有单个类型参数的自定义泛型列表类,以及如何实现 IEnumerable<T> 以便对列表的内容启用 foreach 迭代。此示例还演示客户端代码如何通过指定类型参数来创建该类的实例,以及该类型参数的约束如何实现对类型参数执行其他操作。
using System;using System.Collections;using System.Collections.Generic;using System.Text;namespace Generics_CSharp{ // 尖括号中的类型参数 T。 public class MyList<T> : IEnumerable<T> { protected Node head; protected Node current = null; // 嵌套类型也是 T 上的泛型 protected class Node { public Node next; // T 作为私有成员数据类型。 private T data; // 在非泛型构造函数中使用的 T。 public Node(T t) { next = null; data = t; } public Node Next { get { return next; } set { next = value; } } // T 作为属性的返回类型。 public T Data { get { return data; } set { data = value; } } } public MyList() { head = null; } // T 作为方法参数类型。 public void AddHead(T t) { Node n = new Node(t); n.Next = head; head = n; } // 实现 GetEnumerator 以返回 IEnumerator<T>,从而启用列表的 // foreach 迭代。请注意,在 C# 2.0 中, // 不需要实现 Current 和 MoveNext。 // 编译器将创建实现 IEnumerator<T> 的类。 public IEnumerator<T> GetEnumerator() { Node current = head; while (current != null) { yield return current.Data; current = current.Next; } } // 必须实现此方法,因为 // IEnumerable<T> 继承 IEnumerable IEnumerator IEnumerable.GetEnumerator() { return GetEnumerator(); } } public class SortedList<T> : MyList<T> where T : IComparable<T> { // 一个未优化的简单排序算法, // 该算法从低到高对列表元素排序: public void BubbleSort() { if (null == head || null == head.Next) return; bool swapped; do { Node previous = null; Node current = head; swapped = false; while (current.next != null) { // 由于需要调用此方法,因此,SortedList // 类在 IEnumerable<T> 上是受约束的 if (current.Data.CompareTo(current.next.Data) > 0) { Node tmp = current.next; current.next = current.next.next; tmp.next = current; if (previous == null) { head = tmp; } else { previous.next = tmp; } previous = tmp; swapped = true; } else { previous = current; current = current.next; } }// end while } while (swapped); } } // 一个将自身作为类型参数来实现 IComparable<T> 的简单类, // 是对象中的 // 常用设计模式,这些对象 // 存储在泛型列表中。 public class Person : IComparable<Person> { string name; int age; public Person(string s, int i) { name = s; age = i; } // 这会使列表元素 // 按 age 值排序。 public int CompareTo(Person p) { return age - p.age; } public override string ToString() { return name + ":" + age; } // 必须实现 Equals。 public bool Equals(Person p) { return (this.age == p.age); } } class Generics { static void Main(string[] args) { // 声明并实例化一个新的范型 SortedList 类。 // Person 是类型参数。 SortedList<Person> list = new SortedList<Person>(); // 创建 name 和 age 值以初始化 Person 对象。 string[] names = new string[] { "Franscoise", "Bill", "Li", "Sandra", "Gunnar", "Alok", "Hiroyuki", "Maria", "Alessandro", "Raul" }; int[] ages = new int[] { 45, 19, 28, 23, 18, 9, 108, 72, 30, 35 }; // 填充列表。 for (int x = 0; x < names.Length; x++) { list.AddHead(new Person(names[x], ages[x])); } Console.WriteLine("Unsorted List:"); // 打印出未排序的列表。 foreach (Person p in list) { Console.WriteLine(p.ToString()); } // 对列表进行排序。 list.BubbleSort(); Console.WriteLine(String.Format("{0}Sorted List:", Environment.NewLine)); // 打印出排序的列表。 foreach (Person p in list) { Console.WriteLine(p.ToString()); } Console.WriteLine("Done"); } }}希望本文所述对大家的C#程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文以实例形式讲述了C#泛型的用法,有助于读者深入理解C#泛型的原理,具体分析如下:首先需要明白什么时候使用泛型:当针对不同的数据类型,采用相似的逻辑算法,为了
本文实例讲述了C#中泛型委托的用法,并以示例形式较为详细的进行了用法分析。分享给大家供大家参考之用。具体如下:首先,泛型委托是委托的一种特殊形式,虽然感觉看上去
本文以实例形式分析了C#中Predicate与Func泛型委托的用法,分享给大家供大家参考之用。具体如下:先来看看下面的例子:staticvoidMain(st
本文实例讲述了C#实现利用泛型将DataSet转为Model的方法。分享给大家供大家参考。具体如下:因为网站需要用C#开发,习惯了java的泛型,所以看了一下C
一、泛型的基本概念java与c#一样,都存在泛型的概念,及类型的参数化。java中的泛型是在jdk5.0后出现的,但是java中的泛型与C#中的泛型是有本质区别