iOS單例的創(chuàng)建與銷(xiāo)毀示例
單例:單例模式使一個(gè)類(lèi)只有一個(gè)實(shí)例.單例是在使用過(guò)程,保證全局有唯一的一個(gè)實(shí)例.這樣,才能滿足統(tǒng)一管理的功能.例如,一個(gè)數(shù)據(jù)庫(kù),只需要全局統(tǒng)一的讀取,寫(xiě)入操作.不要多個(gè)實(shí)例去讀寫(xiě).d單例是唯一實(shí)例,它不等同于一直伴隨這app的生命周期.下面,我會(huì)從單例的創(chuàng)建與銷(xiāo)毀去分析單例.
單例的創(chuàng)建
單例的創(chuàng)建分為arc與mrc,兩種模式下的創(chuàng)建.
ARC 下的創(chuàng)建
- 先定義一個(gè)靜態(tài)的instance. static MyClass _instance;
- 重寫(xiě)allocWithZone方法.此方法為對(duì)象分配空間必須調(diào)用方法.
- 定一個(gè)個(gè)share的類(lèi)方法.能夠被全局調(diào)用的.此方法里需要考慮線程安全問(wèn)題
- 如果需要copy,需要遵守NSCopying協(xié)議,以及在copyWithZone中,直接返回self;
例子
static Myclass _instance;
方法一:
+(id)shareInstance{
@synchronized(self){
if(_instance == nil)
_instance = [MyClass alloc] init];
}
return _instance;
}
方法二:
+(id)shareInstance{
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
if(_instance == nil)
_instance = [MyClass alloc] init];
});
return _instance;
}
以上兩種方法都是線程安全的.不過(guò)蘋(píng)果官方現(xiàn)在提倡方法二.
This method exists for historical reasons; memory zones are no longer used by Objective-C. You should not override this method.
//重寫(xiě)allocWithZone,里面實(shí)現(xiàn)跟方法一,方法二一致就行.
+(id)allocWithZone:(struct _NSZone *)zone{
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
if(_instance == nil)
_instance = [MyClass alloc] init];
});
return _instance;
}
這個(gè)函數(shù)重寫(xiě),是錯(cuò)誤的。請(qǐng)讀者注意。
//保證copy時(shí)相同
-(id)copyWithZone:(NSZone *)zone{
return _instance;
}
這樣就是一個(gè)完整的單例,保證怎么創(chuàng)建都是唯一的.
MRC下的創(chuàng)建 創(chuàng)建過(guò)程跟ARC下步驟一樣.不過(guò)要處理一些內(nèi)存管理的函數(shù).
//不需要計(jì)數(shù)器+1
- (id)retain {
return self;
}
//不需要. 堆區(qū)的對(duì)象才需要
- (id)autorelease {
return self;
}
//不需要
- (oneway void)release {
}
//不需要計(jì)數(shù)器個(gè)數(shù). 直接返回最大無(wú)符號(hào)整數(shù)
- (NSUInteger)retainCount {
return UINT_MAX; //參照常量區(qū)字符串的retainCount
}
這樣就能保證這個(gè)單例不會(huì)被無(wú)意釋放.
單例的銷(xiāo)毀
前面講了單例的創(chuàng)建,但是有個(gè)別情況需要銷(xiāo)毀單例.
下面分別從兩種創(chuàng)建方法對(duì)應(yīng)兩種銷(xiāo)毀形式.
方法一:
+(void)attemptDealloc{
[_instance release]; //mrc 需要釋放,當(dāng)然你就不能重寫(xiě)release的方法了.
_instance = nil;
}
方法二:
1. 必須把static dispatch_once_t onceToken; 這個(gè)拿到函數(shù)體外,成為全局的.
2.
+(void)attempDealloc{
onceToken = 0;
// 只有置成0,GCD才會(huì)認(rèn)為它從未執(zhí)行過(guò).它默認(rèn)為0.這樣才能保證下次再次調(diào)用shareInstance的時(shí)候,再次創(chuàng)建對(duì)象.
[_instance release];
_instance = nil;
}
以上兩種方法即為銷(xiāo)毀單例的方法.
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iOS中長(zhǎng)條藍(lán)色按鈕(button)實(shí)現(xiàn)代碼
本文通過(guò)實(shí)例代碼給大家介紹了iOS中長(zhǎng)條藍(lán)色按鈕(button)實(shí)現(xiàn)方法,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-08-08
IOS self和super詳解實(shí)現(xiàn)原理及區(qū)別
這篇文章主要介紹了iOS self和super詳解實(shí)現(xiàn)原理及區(qū)別的相關(guān)資料,這里不僅說(shuō)明區(qū)別并介紹實(shí)現(xiàn)原理,具有參考價(jià)值,需要的朋友可以參考下2016-12-12
iOS中實(shí)現(xiàn)檢測(cè)Zoombie對(duì)象的具體方法
這篇文章主要給大家介紹了關(guān)于iOS中實(shí)現(xiàn)檢測(cè)Zoombie對(duì)象的具體方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01
Swift 2.1 為 UIView 添加點(diǎn)擊事件和點(diǎn)擊效果
本文主要介紹 Swift UIView,這里給大家提供代碼示例作為參考為UIView 添加點(diǎn)擊事件和點(diǎn)擊效果,希望能幫助IOS開(kāi)發(fā)的同學(xué)2016-07-07
iOS 利用動(dòng)畫(huà)和貝塞爾實(shí)現(xiàn)咻咻效果
這篇文章主要介紹了iOS 利用動(dòng)畫(huà)和貝塞爾實(shí)現(xiàn)咻咻效果的相關(guān)資料,需要的朋友可以參考下2016-09-09
IOS設(shè)置QQ小紅點(diǎn)消除的方法(一鍵退朝)
這篇文章主要介紹了IOS設(shè)置QQ小紅點(diǎn)消除的方法(一鍵退朝),對(duì)ios設(shè)置小紅點(diǎn)消除相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01

