2

@界面

//
//  Created by macbook on 31.05.12.
//
// To change the template use AppCode | Preferences | File Templates.
//


#import <Foundation/Foundation.h>


@interface CESettings : NSObject
+ (CESettings *)sharedInstance;

- (void)save;
@end

@执行

//
//  Created by macbook on 31.05.12.
//
// To change the template use AppCode | Preferences | File Templates.
//


#import "CESettings.h"

@interface CESettings ()
@property(nonatomic, strong) NSUserDefaults *userDefaults;
@end

@implementation CESettings
@synthesize userDefaults = _userDefaults;

#pragma mark - Singleton
static CESettings *_instance = nil;
+ (CESettings *)sharedInstance {
    @synchronized (self) {
        if (_instance == nil) {
            _instance = [self new];
        }
    }

    return _instance;
}

- (id)init {
    self = [super init];
    if (self) {
        self.userDefaults = [NSUserDefaults standardUserDefaults];
    }

    return self;
}

#pragma mark - Methods
- (void)save {
    [self.userDefaults synchronize];
}

@end

我有一个用于应用程序设置的类。该类有一个创建单例的方法和一个 init 方法。两者有什么用..?我认为如果存在 sharedInstance 方法,则不需要 init ......如果我错了,请纠正我.. 任何帮助表示赞赏。

4

3 回答 3

7

init方法是new在调用[self new]. 它本质上是一样的

_instance = [[CESettings alloc] init];

但需要更少的输入并避免硬编码CESettings类的名称。

实现单例的更好方法是使用dispatch_once,如下所示:

+ (CESettings*)sharedInstance
{
    static dispatch_once_t once;
    static CESettings *_instance;
    dispatch_once(&once, ^ { _instance = [self new]; });
    return _instance;
}
于 2013-05-16T10:30:10.360 回答
3

从以下文档NSObject

+ (id)new

分配接收类的新实例,向其发送初始化消息,并返回初始化对象。

您正在调用[self new]单例创建者方法,该方法又会分配一个新实例并向其发送init消息。

于 2013-05-16T10:29:53.067 回答
1

sharedInstance 类方法只负责分配和初始化一个对象,然后总是返回它。

你没有通过那个方法你可以自己调用 alloc init 它也可以

所以需要init来保持alloc/init应该如何工作的语义

于 2013-05-16T10:31:19.023 回答