我有一个应用程序从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
块中?如果是这样,它应该是什么样的? (我的dumpCache:
是否应该被包裹起来?)如果没有,我应该如何确保我所做的事情是安全的?