原子性:并发编程中确保其操作具备整体性,系统其它部分无法观察到中间步骤,只能看到操作前后的结果。
决定编译器生成的getter和setter是否原子(natomic)
操作。
因此,
atomic 效率较低,因为要保证操作完整,线程相对安全;
nonatomic 不加同步,多线程并发访问效率高,但线程不安全。
由于锁定机制开销较大,一般 iOS 开发中会使用 nonatomic。
- atomic 也不是绝对的线程安全。当多个线程同时调用 setter 和 getter 时,就会导致获取的值不一样。
兼顾线程安全和效率的方案
要想线程绝对安全,就要使用 @synchronized
同步锁。
// 同步锁
-(NSString *)name{ @synchronized(self) { return _name; } } -(void)setName:(NSString *)name{ @synchronized(self) { _name = name; } }
但是由于同步锁有等待操作,会降低代码效率。
为了兼顾线程安全和提升效率,可采用 GCD 并发队列进行优化。getter 使用同步派发,setter 使用异步栅栏。
// 并发队列
_queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0); -(NSString *)name{ __block NSString *localName; dispatch_sync(_queue, ^ { localName = _name; }); return localName; } -(void)setName:(NSString *) name{ dispatch_barrier_async(_queue, ^{ _name = name; }); }