.NET中的泛型、接口、基类、继承混合使用

泛型、接口、基类、继承这些概念在面向对象程序中本来就很抽象,下面结合一个实例来看看它们如何混合使用

首先建立下图所示的项目。项目为Console项目,其中IClass.cs为接口文件,其它为普通cs文件。BaseClass为基类,ClassA和ClassB继承自BaseClass和接口IClass。InvokeClass为调用类,在这个类里面使用泛型和接口调用ClassA和ClassB中的接口方法。Program为启动Console项目的文件。

project

项目文件代码如下:

IClass.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { public interface IClass { string GetClassName(); } }

BaseClass.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { class BaseClass { public virtual string GetClassName(string className) { return className; } } }

ClassA.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { class ClassA : BaseClass, IClass { #region IClass Members public string GetClassName() { return base.GetClassName("ClassA"); } #endregion } }

ClassB.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { class ClassB :BaseClass, IClass { #region IClass Members public string GetClassName() { return base.GetClassName("ClassB"); } #endregion } }

InvokeClass.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { public class InvokeClass { public string GetClassName<T>(T item)where T:IClass { return item.GetClassName(); } } }

Program.cs

using System; using System.Collections.Generic; using System.Text; namespace GenericTypesAndInterface { class Program { static void Main(string[] args) { InvokeClass invokeClass = new InvokeClass(); Console.WriteLine(invokeClass.GetClassName<ClassA>(new ClassA())); Console.WriteLine(invokeClass.GetClassName<ClassB>(new ClassB())); Console.ReadLine(); } } }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C#,可以使用泛型来指定一个类的基类,同时也可以使用泛型约束来限制泛型类型参数的类型。通过泛型基类泛型约束,可以实现更加灵活和可复用的代码。 以下是一个示例代码,演示了如何定义一个泛型类,并指定其基类以及泛型约束: ```csharp public class MyBaseClass { public void BaseMethod() { Console.WriteLine("BaseMethod called."); } } public class MyGenericClass<T> : MyBaseClass where T : SomeType { public void GenericMethod(T item) { Console.WriteLine("GenericMethod called."); // 可以访问 MyBaseClass 的成员 BaseMethod(); // 可以使用 T 类型的参数 item 进行操作 Console.WriteLine($"Item: {item}"); } } ``` 在上面的示例,`MyBaseClass` 是一个基类,`BaseMethod` 是其成员方法。`MyGenericClass<T>` 是一个泛型类,泛型类型参数 `T` 受到 `SomeType` 泛型约束限制,并且继承自 `MyBaseClass`。在 `MyGenericClass<T>` ,可以访问 `MyBaseClass` 的成员方法,并且使用 `T` 类型的参数进行操作。 使用示例代码: ```csharp MyGenericClass<int> instance = new MyGenericClass<int>(); instance.GenericMethod(42); ``` 在上面的代码,我们创建了一个 `MyGenericClass<int>` 的实例,并调用了 `GenericMethod` 方法,传入了整数类型的参数 `42`。输出结果如下: ``` GenericMethod called. BaseMethod called. Item: 42 ``` 总结起来,通过在泛型指定基类泛型约束,可以使泛型继承自指定的基类,并对泛型类型参数进行类型约束,提供更加灵活和可复用的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值