單例模式(Singleton Pattern) 確保某一個類只有一個實例,而且自行實例化并向整個系統提供這個實例,這個類成為單例類,它提供全局訪問方法。
單例模式三要點:
某個類只能有一個實例它必須自行創建這個實例它必須自行向整個系統提供這個實例使用場景:當一個系統要求只有一個實例時可使用單例模式。
iOS 單例的兩種寫法: 第一種:
//1.設置成靜態全局變量static Setting *set = nil;+(Setting *)sharedSetting{ @synchronized(self){//2.保證線程安全 // 3.當對象不存在時,創建對象,第二次再調用方法的時候,由于set是靜態的,所以不為空,不會再重新創建對象 if (!set) { set = [[Setting alloc]init]; } } //返回自己 return set;}//這個方法是在調用alloc方法時,alloc內部實際調用的創建對象的方法//我們重寫這個方法,保證在這個方法的內部創建的對象就是set對象即可+(id)allocWithZone:(struct _NSZone *)zone{ @synchronized(self){ if (!set) { set = [super allocWithZone:zone]; } } return set;}第二種:
+ (id)sharedSetting{ static Setting *setting = nil; static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ setting = [[self alloc] init]; }); return setting;}+(id)allocWithZone:(struct _NSZone *)zone{ static Setting *setting = nil; static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ setting = [super allocWithZone:zone]; }); return setting;}以上兩種方法對于只用【shareSetting】類方法獲取的話【allocWithZone】方法創建實例是可以不重寫的,但是,為防止一不小心用alloc方法創建實例,座椅最好還是重寫一下。而且在實際中,為保證對象的絕對唯一,并不是只需重寫這一個方法,還有 copyWithZone 等
//注意:在實際中,若想保證對象的絕對唯一,并不是只需重寫這一個方法,還有 copyWithZone 等//實現這個方法的類- (id)copyWithZone:(nullable NSZone *)zone{ return self;}- (id)mutableCopyWithZone:(nullable NSZone *)zone{ return self;}結果展示一下: 
其中要想對copyWithZone方法進行進一步了解的點這里
如有不當,歡迎指正。
新聞熱點
疑難解答