iOS單例模式的實(shí)現
單例是指靜態(tài)分配的實(shí)例,而 iphone sdk 中全是這種實(shí)例,例如
本文引用地址:http://dyxdggzs.com/article/201610/305923.htm[UIApplication sharedApplication] 返回一個(gè)指向代表應用程序的單例對象的指針。[UIDevice currentDevice] 獲取一個(gè)代表所有使用硬件平臺的對象。
將類(lèi)方法與單例相結合,便可以在程序的任何地方訪(fǎng)問(wèn)靜態(tài)實(shí)例,而無(wú)需使用指向對象的指針或保存它的實(shí)例變量。創(chuàng )建類(lèi)的唯一實(shí)例(普通單例)的函數示例:
//在很多時(shí)候,我們使用某個(gè)類(lèi)的唯一實(shí)例。最常見(jiàn)的就是一個(gè)程序的主類(lèi),以下是以名為 RootViewController 創(chuàng )建的一個(gè)單例函數:
static RootViewController *sharedRootController = nil;
+(RootViewController *) sharedController{
@synchronized(self)
{
if (sharedRootController == nil)
{
sharedRootController = [[[self alloc] init] autorelease];
}
}
return sharedRootController;
}
+(id) allocWithZone:(NSZone *)zone
{
@synchronized(self)
{
if (sharedRootController == nil)
{
sharedRootController = [super allocWithZone:zone];
return sharedRootController;
}
}
return nil;
}
代碼說(shuō)明:
1、synchronized 這個(gè)主要是考慮多線(xiàn)程的程序,這個(gè)指令可以將{ } 內的代碼限制在一個(gè)線(xiàn)程執行,如果某個(gè)線(xiàn)程沒(méi)有執行完,其他的線(xiàn)程如果需要執行就得等著(zhù)。
2、網(wǎng)上搜索的代碼,好像有一個(gè)沒(méi)有加入 autorelease,我覺(jué)得應該需要加。因為如果調用的函數沒(méi)有release就麻煩了(我覺(jué)得,iOS 上的程序,對于創(chuàng )建用于函數返回值的,都應該考慮 autorelease)。
3、allocWithZone 這個(gè)是重載的,因為這個(gè)是從制定的內存區域讀取信息創(chuàng )建實(shí)例,所以如果需要的單例已經(jīng)有了,就需要禁止修改當前單例,所以返回 nil。
評論