Kar*_*207 2 java concurrency concurrenthashmap nsmutabledictionary ios
我有一个NSMuableDictionary并行线程访问,其中几个线程将枚举,几个线程将变异.但我们无法实现这一点
"在枚举期间不能突变收藏"
.使用NSLock,但随后锁定字典直到枚举完成将导致性能降低.在java中我们有并发的hashmap,它足够聪明,可以照顾这个场景.有没有更好的想法实现这一点iOS?.请帮助.
对Objective-C容器的读/写访问通常不是线程安全的.
您可以通过将容器与专用调度队列相关联,然后在该队列上执行所有读写访问来解决并发问题.队列可以是串行的也可以是并发的.
您可以在任何专用线程上调用以下方法.但是,我建议最终将您的实现切换为调度lib.
dispatch_queue_t sync_queue = dispatch_queue_create("sync_queue", NULL);
Run Code Online (Sandbox Code Playgroud)
可以异步进行写访问:
- (void) addItem:(id)item forKey:(NSString*)key {
dispatch_async(sync_queue, ^{
[self.dict setObject:item forKey:key];
});
}
Run Code Online (Sandbox Code Playgroud)
返回值的读取访问必须是同步的:
- (id) itemForKey:(NSString*)key {
__block id item;
dispatch_sync(sync_queue, ^{
item = [self.dict objectForKey:key];
});
return item;
}
Run Code Online (Sandbox Code Playgroud)
您可以为任何任务定义类似的包装器:
- (void) iterate {
dispatch_async(sync_queue, ^{
for (id item in self.dict) {
...
}
});
}
Run Code Online (Sandbox Code Playgroud)
dispatch_queue_t sync_queue = dispatch_queue_create("sync_queue", DISPATCH_QUEUE_CONCURRENT);
Run Code Online (Sandbox Code Playgroud)
写访问可以异步进行,需要一个障碍:
- (void) addItem:(id)item forKey:(NSString*)key {
dispatch_barrier_async(sync_queue, ^{
[self.dict setObject:item forKey:key];
});
}
Run Code Online (Sandbox Code Playgroud)
返回值的读访问必须是同步的,并且它不需要障碍.基本上,同步和并发队列没有区别:
- (id) itemForKey:(NSString*)key {
__block id item;
dispatch_sync(sync_queue, ^{
item = [self.dict objectForKey:key];
});
return item;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2211 次 |
| 最近记录: |