我有一个应用程序可以从 Web 服务下载信息并将其缓存在内存中。具体来说,我的单例缓存类包含一个实例变量 NSMutableDictionary *memoryDirectory
,它包含所有缓存数据。这个缓存中的数据可以很容易地重新下载,所以当我收到 UIApplicationDidReceiveMemoryWarningNotification
时,我调用一个方法来简单地调用
- (void) dumpCache:(NSNotification *)notification
{
memoryDirectory = nil;
}
我有点担心这里的线程安全。 (我承认我对一般的线程知之甚少,更不用说 Cocoa 的实现了。)缓存是一个可变字典,其值是可变字典,因此有两个级别的键来访问数据。当我写入缓存时,我会做这样的事情:
- (void) addDataToCache:(NSData *)data
forKey:(NSString *)
subkey:(NSString *)subkey
{
if (!memoryDirectory)
memoryDirectory = [[NSMutableDictionary alloc] init];
NSMutableDictionary *methodDictionary = [memoryDirectory objectForKey:key];
if (!methodDictionary) {
[memoryDirectory setObject:[NSMutableDictionary dictionary] forKey:key];
methodDictionary = [memoryDirectory objectForKey:key];
}
[methodDictionary setObject:data forKey:subkey];
}
我担心在这个过程的某个时候,dumpCache:
会清空字典,而我将不得不做一堆 setObject:forKey :
什么都不做。这不是致命的,但您可以想象如果在我读取缓存时发生这种情况可能会出现什么问题。
将我所有的缓存读取和写入包装在某种 @synchronized
block 中是否足够?如果是这样,它应该是什么样子? (我的 dumpCache:
是否应该被类似地包装?)如果不是,我应该如何确保我正在做的事情是安全的?
最佳答案
不使用 NSMutableDictionary
,考虑使用 NSCache
,这是线程安全的。参见 this answer例如用法。祝你好运!
关于ios - NSMutableDictionary 访问和销毁的线程安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8982474/