【学习日记2】泛型实现单例基类

泛型是什么

        泛型实现的是类型参数化,简单来说就是定义/申明的时候不需要给到精确的数据类型,后面使用类/方法的时候再进行指定。学术一点叫做“类型参数化”。

为什么用泛型

        如果我们要做一个底层为数组的列表类,那么在不使用object的前提下,我们需要创建很多个类型的列表类,毕竟常规方法的时候数组是需要指定一个类型的。

        但如果我们使用泛型就不一样了,我们可以用一个占位符替代原先必须写死的类型,使用的时候再根据需要传入类型的参数。

        这样就达到了代码重用的目的。所以归根结底,泛型是便于代码的重用。

        所以,当我们要写很多Manager的时候,就需要写很多单例的先决条件,这也太麻烦了。所以,我们可以让需要变成单例的类直接继承泛型的单例基类,这样就不用多此一举了。

如何用泛型实现单例模式基类

泛型约束

        泛型占位符可以是任何类型,但为了代码规范性,我们往往需要对其施加一些约束。这里简单介绍几种常见的泛型约束。

        关键字:where

//值类型   where 泛型字母 : struct
//引用类型 where 泛型字母 : class
//存在无参公共构造函数 where 泛型字母 : new()
//某个类本身或其派生类 where 泛型字母 : 类名
//某个接口的派生类型 where 泛型字母 : 接口名
//另一个泛型类型本身或派生类型 where 泛型字母 : 另一个泛型字母

实现

class Singleton<T> where T : new()
    {
        private T instance = new T();

        public T Instance
        {
            get
            {
                return instance;
            }
        }
    }

        可以看到,我们定义了Singleton的类并且给予了泛型约束为new(),这意味着T必须是存在无参公共构造函数的数据类型。

        在这个类中,我们将单例模式需要的两个必要元素做了声明,即私有的T类唯一对象和对应的构造器属性。这样以后我们需要什么类为单例模式,直接继承这个Singleton<T>的泛型基类即可。

        当然这么写是有一个瑕疵的。即我们无法让无参构造函数私有化,有单例类被强制new出来的可能性,不过在团队合作中可以提前规范来避免这种错误的发生。

使用方法

class GameMgr : Singleton<GameMgr>
    {
        public int sceneId;
        //本身的逻辑
    }

如代码所示,直接继承并设置泛型类型为该类名称即可。

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在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 ``` 总结起来,通过在泛型类中指定基类泛型约束,可以使泛型类继承自指定的基类,并对泛型类型参数进行类型约束,提供更加灵活和可复用的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值