В моем приложении я просматриваю и изменяю измененный массив из нескольких потоков. Сначала он разбивался, когда я пытался получить доступ к объекту с помощью objectAtIndex
, потому что индекс был за пределами (объект в этом индексе уже удален из массива в другом потоке). Я искал в Интернете, как решить эту проблему, и решил попробовать это решение. Я создал класс с свойством NSMutableArray
, см. Следующий код:
@interface SynchronizedArray()
@property (retain, atomic) NSMutableArray *array;
@end
@implementation SynchronizedArray
- (id)init
{
self = [super init];
if (self)
{
_array = [[NSMutableArray alloc] init];
}
return self;
}
-(id)objectAtIndex:(NSUInteger)index
{
@synchronized(_array)
{
return [_array objectAtIndex:index];
}
}
-(void)removeObject:(id)object
{
@synchronized(_array)
{
[_array removeObject:object];
}
}
-(void)removeObjectAtIndex:(NSUInteger)index
{
@synchronized(_array)
{
[_array removeObjectAtIndex:index];
}
}
-(void)addObject:(id)object
{
@synchronized(_array)
{
[_array addObject:object];
}
}
- (NSUInteger)count
{
@synchronized(_array)
{
return [_array count];
}
}
-(void)removeAllObjects
{
@synchronized(_array)
{
[_array removeAllObjects];
}
}
-(id)copy
{
@synchronized(_array)
{
return [_array copy];
}
}
и я использую этот класс вместо старого измененного массива, но приложение все еще терпит крах в этой строке: return [_array objectAtIndex:index];
Я тоже пробовал этот подход с NSLock
, но без везения. Что я делаю неправильно и как это исправить?