- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
有人可以向我解释在以下示例代码块中使用 __autoreleasing
的目的吗?
- (void)execute:(NSError * __autoreleasing *)error {
// do stuff, possibly assigning error if something went wrong
}
我删除了 __autoreleasing
并且一切似乎仍然可以正常编译/运行。我开始使用 obj-c post ARC,所以我从来没有真正学习/理解所有那些双下划线 thingamajigs。我读过 ARC transition guide ,但我不完全理解他们的 NSError 示例。
最佳答案
考虑 ARC 如何处理变量 - 每个引用变量都有一个模式(隐式或显式):strong、weak 等。这模式让 ARC 知道如何处理对该变量的读取和写入;例如对于 strong 变量,读取不需要额外的操作,而写入需要在变量被新引用替换之前释放变量中的现有引用。 ARC 需要知道任何变量的模式才能发挥作用。
现在考虑由 reference 传递的变量,例如对于您的 execute
,您将接到如下电话:
NSError *myError = nil;
...
[someObject execute:&myError]; // pass the variable itself by reference, not the variables value
而 execute
的主体将包含一个如下的赋值:
- (void)execute:(NSError * __autoreleasing *)error
{
...
if (error != NULL)
*error = [NSError ...]; // assign indirectly via the reference to a variable
...
}
现在,对于间接赋值,ARC 需要知道被引用变量的模式,以便知道如何读写。这就是 __autoreleasing
在声明中的内容,它告诉 ARC 它已经传递了对模式为 autoreleasing 的变量的引用,并告诉 ARC 如何读取和写入变量的内容。删除 __autoreleasing
并假定默认模式,在这种情况下,我建议显式肯定是好的。
autoreleasing 模式意味着变量包含一个不拥有的引用,如果需要读取应该retain,写入可以只写入。主要用于通过引用传递的变量。
您可能会注意到,在上面的示例中,变量 myError
具有模式 strong(隐式),但它通过引用传递为 autoreleasing - 编译器通过引入一个临时自动释放变量来自动处理这个问题,复制 而不 在 myError
中保留当前引用,并将临时引用作为参数传递给 执行:
。调用返回后,编译器会从临时变量中对 myError
进行正常赋值,这会导致释放任何旧引用并保留返回的引用。
更多详情见Apple's Transitioning to ARC Release Notes
评论跟进
问:__autoreleasing
是隐式设置的吗?
A:嗯Apple's文档不具体,但 Clang documentation表示它对于间接参数是隐式的。如上所述,我建议明确,清晰是一件好事™。
问:位置重要吗?
A:是的,也不是……这是一个 C 声明,是问答题(“以下声明什么……”)。限定符应该在两个星号之间,因为它是一个 指向对象的(类型变量)自动释放指针的指针,但 Apple 声明编译器是“宽恕的”,但并未具体说明它宽恕的内容。安全起见,把它放在正确的地方。
问:在进行间接赋值之前,是否不应该测试 error
是否为 NULL
?
A:你当然应该在做间接处理之前的某个地方。显示的代码只是一个大纲,这些细节被 ...
所省略和覆盖。然而,由于它多年来被提出了几次,可能我省略了太多,所以添加了一个合适的 if
。
关于objective-c - NSError 和 __autoreleasing,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13587742/
我在返回错误的 Apple 函数中注意到了这种模式 error:(NSError *__autoreleasing *)outError 我理解它的意思,它是指向指针的指针,用于执行结果(仅使用 *
在 AFNetworking 中我找到了这个函数: - (NSURLSessionUploadTask *)uploadTaskWithRequest:(NSURLRequest *)request
我有一个街区; typedef void (^SIResponseHandler) (id obj, NSString *error); 和方法: + (void)uploadPhoto:(UIIma
如何使变量的地址成为 NSObject 中的强属性?我有一个名为 SCPFMessageThreadQuery 的类,它是通过传递 SCPFMessageThread 变量的地址来分配初始化的。 @i
所以我像往常一样将一个指向 NSError 对象的指针传递给一个方法。它曾经很简单: -(BOOL)foo:(NSString *)string error:(NSError **)error 但是对
我拼命想了解 __autoreleasing 关键字在 Objective-C 中的用法。我已仔细阅读以下问题的答案: In which situations do we need to write
根据 Transitioning to ARC Release Notes : __autoreleasing is used to denote arguments that are passed
有人可以向我解释在以下示例代码块中使用 __autoreleasing 的目的吗? - (void)execute:(NSError * __autoreleasing *)error { /
我一直都知道这种模式是管理 NSError** 参数(特别是 BOOL 返回值和 NSError* __autoreleasing * 参数: -(BOOL)doSomethingWithString
我正在尝试将旧的非 ARC 项目转换为 ARC,但出现此编译错误:“无法在 block 中捕获 __autoreleasing 变量” - (void)animateViewController:(_
-(NSData *)jsonRepresentation:(NSError **error)error { NSDictionary *dict = [self getDictRepresen
考虑这段代码: @implementation MyClass -(void)dealloc { NSLog(@"MyClass dealloc: %@", self); } @end @im
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: In which situations do we need to write the __autorele
根据 Cocoa 的“创建规则”,返回新实例化对象的方法必须以 new、create 或 copy 开头,如果所有权转移给调用者。 假设我有一个实现名为 (NSObject *)getCorrectO
在学习 NSInvocations 时,我对内存管理的理解似乎存在差距。 这是一个示例项目: @interface DoNothing : NSObject @property (nonatomic,
我正在尝试完成这个谜题。 __strong 是所有 Objective-C 可保留对象指针(如 NSObject、NSString 等)的默认值。它是一个强引用。 ARC 在作用域末尾用 -relea
为什么 Apple 的方法没有将 NSError** 声明为 NSError * __autoreleasing * ? Transitioning to ARC Release Notes似乎暗示他
我正在尝试从 id __autoreleasing * 转换为 CFTypeRef * (void **)。 我试过: id __autoreleasing *arg = [OCMArg setTo:
在 ARC 下,输出参数采用以下形式(默认情况下;这等同于 NSError **): - (BOOL)tryWithError:(NSError *__autoreleasing *)err; 来自T
我正在尝试使用 PowerPlot 库绘制条形图。因此,我发现只有这个代码可以满足我对负条以及阴影或不透明度的要求。原始示例项目不使用 ARC。但是我的项目使用 ARC。在复制相同的代码时,我在编译项
我是一名优秀的程序员,十分优秀!