OC 中的单例模式

在Objective-C中,可以使用NS_UNAVAILABLE来屏蔽某个初始化方法,使其在编译时不可用。这在某些情况下是很有用的,比如当你想要将某个类设计为单例时。
首先,让我们明确一下什么是单例模式。单例模式是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取该实例。这样可以方便地在整个应用程序中使用同一个实例。
现在,让我们看一下如何使用NS_UNAVAILABLE来屏蔽初始化方法,同时暴露单例方法。
首先,在类的接口文件(.h文件)中,将初始化方法的声明放在@interface中,并使用NS_UNAVAILABLE标记该方法,如下所示:
@interface MyClass : NSObject

- (instancetype)init NS_UNAVAILABLE;

+ (instancetype)sharedInstance;

@end
通过将init方法标记为NS_UNAVAILABLE,编译器将在编译时阻止使用此方法进行对象的初始化。这意味着,不能直接通过init方法来创建MyClass的实例。
然后,在类的实现文件(.m文件)中,定义共享实例的单例方法,如下所示:
@implementation MyClass

+ (instancetype)sharedInstance {
    static MyClass *instance = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        instance = [[self alloc] init];
    });
    return instance;
}

@end
在这个例子中,我们使用了dispatch_once函数来确保sharedInstance方法只会被调用一次,从而保证只有一个实例被创建。
现在,通过调用sharedInstance方法,我们可以获取MyClass的单例实例,如下所示:
MyClass *singleton = [MyClass sharedInstance];
这种方法可以确保我们在整个应用程序中只有一个MyClass的实例,并且可以方便地通过单例方法来获取该实例。
需要注意的是,虽然我们屏蔽了init方法,但实际上我们仍然可以通过以下方式创建实例:
MyClass *instance = [[MyClass alloc] init];
但是这样做会在编译时收到警告,因为init方法被标记为NS_UNAVAILABLE。
总之,使用NS_UNAVAILABLE将初始化方法屏蔽,同时暴露单例方法,可以方便地创建并全局访问一个类的单例实例。

附:单例模式的介绍

单例模式的优点:
  1. 提供了全局访问点:单例模式确保了一个类只有一个实例,并提供了一个全局访问点来获取该实例。这使得在整个应用程序中可以方便地使用同一个实例。
  1. 节省了资源:由于单例模式只创建一个实例,因此可以节省系统资源,并提高性能。
  1. 数据共享:单例模式可以方便地实现数据共享,多个对象可以访问同一个实例,从而简化了数据传递和协作。
单例模式的缺点:
  1. 难以扩展:由于单例模式只有一个实例,因此扩展功能可能会变得困难。当应用程序的需求变化时,可能需要修改单例类的实现,这可能会带来一些风险。
  1. 过度使用单例模式可能导致代码耦合:过度使用单例模式会导致代码的紧密耦合,这会使得单例对象难以进行独立测试和维护。
在什么时候会使用单例模式:
  1. 当你需要在整个应用程序中共享某个对象或状态时,可以考虑使用单例模式。比如,日志记录器、网络管理器等。
  1. 当你需要访问一个独特的资源或服务时,可以使用单例模式来管理该资源或服务的生命周期和访问。
  1. 当你需要限制一个类的实例化,并确保整个应用程序中只有一个实例时,可以使用单例模式来实现。
 
你觉得这篇文章怎么样?
YYDS
比心
加油
菜狗
views

Loading Comments...