gpt4 book ai didi

iOS block 和同步性

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:37:54 25 4
gpt4 key购买 nike

我对我的应用程序中的 block 和同步性有疑问。这是场景:

我有一个 NetworkManager,它使用 AFHTTPRequestOperationManager (AFNetworking 2.0) 来调用服务器。我有一个 ContentStore 类单例,它为应用程序提供内容。应用程序中的任何类都可以向内容存储请求内容,它会传递一个 block 来接收该内容。如果 ContentStore 在内存或存档中有内容,它会将它传递给请求内容的类中的 block 。如果没有,它会向 NetworkManager 发出请求,并将一个 block 传递给 NetworkManager,当内容从服务器到达时,该 block 会调用原始类中的 block 。到目前为止,这一切都很好并且运作良好。

问题是有时类可以在已经为内容发出请求但尚未收到回复时调用 ContentStore 来获取内容。在这种情况下,两个请求会针对相同的内容发送到服务器,这实际上不会造成问题,但效率很低。

我想出了一个系统,该系统执行以下操作:如果正在向服务器请求内容,ContentStore 会将传递给它的所有 block 保存在一个数组中,当从服务器收到回复时 ContentStore循环遍历 block 数组并将内容传递给每个 block 。

这很好用,但我想知道是否有可能出现故障。当一个类为内容调用 ContentStore 并且请求正在进行时,是否可以在下面代码中的 downloadCompletionBlock 循环遍历同一数组时将 block 添加到数组中?

感谢所有花时间理解和回答我的问题的人。如果您需要更多信息,请告诉我。

@interface ContentStore()
@property (nonatomic, strong) NSDictionary *downloadDictionary;
@property (nonatomic, strong) NSMutableArray *downloadBlocksForRequest;
@property (nonatomic, strong) NetworkManger *networkManager;
@end



@implementation ContentStore

- (void) downloadWithCompletionBlock:(void (^)(NSDictionary *))completionBlock
{

if (_downloadDictionary) {
completionBlock(_downloadDictionary);
return;
} else {
_downloadDictionary = [NSKeyedUnarchiver unarchiveObjectWithFile:[self downloadArchivePath]];
if (_downloadDictionary) {
completionBlock(_downloadDictionary);
return;
} else if (_downloadBlocksForRequest) {
[_downloadBlocksForRequest addObject:completionBlock];
return;
} else {
_downloadBlocksForRequest = [[NSMutableArray alloc]init];
[_downloadBlocksForRequest addObject:completionBlock];
}
}

void (^downloadCompletionBlock)(NSDictionary *) = ^(NSDictionary *downloadDictionary)
{
// do other work necessary

[NSKeyedArchiver archiveRootObject:downloadDictionary toFile:[self downloadArchivePath]];
[self setDownloadDictionary:downloadDictionary];

for (int i=0; i<_facesBlocksForRequest.count; i++) {
void (^complBlock)(NSDictionary *) = [_facesBlocksForRequest objectAtIndex:i];
complBlock(downloadDictionary);

}
_downloadBlocksForRequest = nil;

};


[_networkManager downloadWithCompletionBlock:downloadCompletionBlock];

}

最佳答案

NSMutableArray,与 iOS 中的大多数(如果不是全部)可变容器一样,是 not thread-safe .所以你的担心是有道理的,这段代码可能会引入一个非常难以捕捉的错误。您可能希望通过执行以下操作来同步对它的访问

@synchronized(_downloadBlocksForRequest) {
// enumerate _downloadBlocksForRequest, or add an object to it, etc.
}

关于iOS block 和同步性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20616959/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com