.NET泛型通过类型参数实现类型安全、性能提升和代码复用;可定义泛型类如MyStack和泛型方法如Swap;支持约束如where T : class, new()确保类型符合条件,提升灵活性与安全性。

.NET中的泛型(Generics)是一种允许在定义类、方法或接口时使用类型参数的机制。它让开发者编写可重用且类型安全的代码,避免了运行时类型转换和装箱/拆箱操作,提高了性能和代码质量。
泛型的核心优势
类型安全: 编译器在编译期间就能检查类型是否匹配,减少运行时错误。
性能提升: 避免对值类型进行装箱和拆箱操作。
代码复用: 同一套逻辑可以适用于多种数据类型,无需重复编写。
如何创建自己的泛型类
定义一个泛型类时,在类名后添加尖括号,其中T是类型参数的占位符(可以是任意标识符,常用T表示“Type”)。
例如,创建一个简单的泛型栈类:
public class MyStack
{
private List _items = new List();
public void Push(T item)
{
_items.Add(item);
}
public T Pop()
{
if (_items.Count == 0)
throw new InvalidOperationException(“栈为空”);
T item = _items[_items.Count – 1];
_items.RemoveAt(_items.Count – 1);
return item;
}
public int Count => _items.Count;
}
使用这个类时指定具体类型:
var stringStack = new MyStack();
stringStack.Push(“Hello”);
stringStack.Push(“World”);
Console.WriteLine(stringStack.Pop()); // 输出: World
如何创建自己的泛型方法
泛型方法是在方法级别引入类型参数的方法,可以在非泛型类中使用。
例如,在一个普通类中定义泛型方法:
public class Utility
{
public static void Swap(ref T a, ref T b)
{
T temp = a;
a = b;
b = temp;
}
public static T GetDefault()
{
return default(T);
}
}
调用泛型方法:
int x = 10, y = 20;
Utility.Swap(ref x, ref y);
Console.WriteLine($”x={x}, y={y}”); // 输出: x=20, y=10
var defaultValue = Utility.GetDefault(); // null
注意:调用时可以省略类型参数,编译器通常能根据上下文推断出类型(类型推断)。
约束泛型类型(Constraints)
有时需要限制泛型类型必须满足某些条件,比如必须实现某个接口或具有无参构造函数。这时可以使用where关键字添加约束。
常见约束示例:
public class DataProcessor where T : class, new()
{
public T CreateInstance()
{
return new T(); // 要求T有公共无参构造函数
}
}
public interface ILoggable
{
void Log();
}
public void Process(T item) where T : ILoggable
{
item.Log(); // 确保T实现了ILoggable接口
}
常用约束包括:
– where T : class — 引用类型
– where T : struct — 值类型
– where T : new() — 具有公共无参构造函数
– where T : MyBaseClass — 派生自某个类
– where T : IInterface — 实现某个接口
基本上就这些。泛型是.NET中非常强大的特性,合理使用能让代码更灵活、高效和安全。
以上就是.NET中的泛型(Generics)是什么?如何创建自己的泛型类和方法?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1441986.html
微信扫一扫
支付宝扫一扫