zoukankan      html  css  js  c++  java
  • IOS开发中单例模式使用详解

    第一、基本概念

    单例模式是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例类的特殊类。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问。

    第二、在IOS中使用单例模式的情况

    1.如果说创建一个对象会耗费很多系统资源,那么此时采用单例模式,因为只需要一个实例,会节省alloc的时间

    2.在IOS开发中,如果很多模块都要使用同一个变量,此时如果把该变量放入单例类,则所有访问该变量的调用变得很容易,否则,只能通过一个模块传递给另外一个模块,这样增加了风险和复杂度

    第三、创建单例模式的基本步骤

    1.声明一个单例对象的静态实例,并初始化为nil

    2.声明一个类的工厂方法,生成一个该类的实例,并且只会生成一个

    3.覆盖allcoWithZone方法,确保用户在alloc 时,不会产生一个多余的对象

    4.实现NSCopying协议,覆盖release,autorelease,retain,retainCount方法,以确保只有一个实例化对象

    5.在多线程的环境中,注意使用@synchronized关键字 

    //
    //  UserContext.h
    //  SingleDemo
    //
    //  Created by andyyang on 9/30/13.
    //  Copyright (c) 2013 andyyang. All rights reserved.
    //
    
    #import <Foundation/Foundation.h>
    
    @interface UserContext : NSObject
    @property (nonatomic,retain) NSString *username;
    @property(nonatomic,retain)NSString *email;
    +(id)sharedUserDefault;
    @end
    

     

    //
    //  UserContext.m
    //  SingleDemo
    //
    //  Created by andyyang on 9/30/13.
    //  Copyright (c) 2013 andyyang. All rights reserved.
    //
    
    #import "UserContext.h"
    
    static UserContext *singleInstance=nil;
    @implementation UserContext
    
    +(id)sharedUserDefault
    {
        if(singleInstance==nil)
        {
            @synchronized(self)
            {
                if(singleInstance==nil)
                {
                    singleInstance=[[[self class] alloc] init];
                    
                }
            }
        }
        return singleInstance;
    }
    
    + (id)allocWithZone:(NSZone *)zone;
    {
        NSLog(@"HELLO");
    if(singleInstance==nil)
    {
        singleInstance=[super allocWithZone:zone];
    }
        return singleInstance;
    }
    -(id)copyWithZone:(NSZone *)zone
    {
        NSLog(@"hello");
        return singleInstance;
    }
    -(id)retain
    {
        return singleInstance;
    }
    - (oneway void)release
    
    {
    }
    - (id)autorelease
    {
        return singleInstance;
    }
    
    - (NSUInteger)retainCount
    {
        return UINT_MAX;
    }@end


    #import <Foundation/Foundation.h>
    #import "UserContext.h"
    
    int main(int argc, const char * argv[])
    {
    
        @autoreleasepool {
            
           UserContext *userContext1=[UserContext sharedUserDefault];
            UserContext *userContext2=[UserContext sharedUserDefault];
            UserContext *userContext3=[[UserContext alloc] init];
            UserContext *userContext4=[userContext1 copy];
            // insert code here...
            NSLog(@"Hello, World!");
            
        }
        return 0;
    }
    


    result:


  • 相关阅读:
    HDU 3605 Escape 最大流
    HDU 3416 Marriage Match IV (最短路径&&最大流)
    洛谷1508 简单记忆化搜索
    洛谷1880 区间dp+记忆化搜索 合并石子
    洛谷1063 +区间dp(经典问题)
    洛谷1074 靶状数独dfs 排序、记录、搜索
    hdu3368 dfs 下棋
    hdu1258 dfs 给一个指定的target数和一个数列,要求不重复选择其中的数使得和为target并打印,结果不可重复。
    hdu1181 dfs 字符串首尾可拼接,问是否可寻找到一条字串路径使得首尾分别是‘b’和‘m’,简单的搜索+回溯
    hdu1078 dfs+dp(记忆化搜索)搜索一条递增路径,路径和最大,起点是(0,0)
  • 原文地址:https://www.cnblogs.com/james1207/p/3348008.html
Copyright © 2011-2022 走看看