有人可以向我解释在以下示例代码块中使用 __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/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby1.9+ 关于ruby-主要:Objectwhenrun
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我正在尝试为我的iOS应用程序设置cocoapods但是当我执行命令时:sudogemupdate--system我收到错误消息:当前已安装最新版本。中止。当我进入cocoapods的下一步时:sudogeminstallcocoapods我在MacOS10.8.5上遇到错误:ERROR:Errorinstallingcocoapods:cocoapods-trunkrequiresRubyversion>=2.0.0.我在MacOS10.9.4上尝试了同样的操作,但出现错误:ERROR:Couldnotfindavalidgem'cocoapods'(>=0),hereiswhy:U
在Ruby(尤其是Rails)中,您经常需要检查某物是否存在,然后对其执行操作,例如:if@objects.any?puts"Wehavetheseobjects:"@objects.each{|o|puts"hello:#{o}"end这是最短的,一切都很好,但是如果你有@objects.some_association.something.hit_database.process而不是@objects呢?我将不得不在if表达式中重复两次,如果我不知道实现细节并且方法调用很昂贵怎么办?显而易见的选择是创建一个变量,然后测试它,然后处理它,但是你必须想出一个变量名(呃),它也会在内存中
如thisanswer中所述,Array.new(size,object)创建一个数组,其中size引用相同的object。hash=Hash.newa=Array.new(2,hash)a[0]['cat']='feline'a#=>[{"cat"=>"feline"},{"cat"=>"feline"}]a[1]['cat']='Felix'a#=>[{"cat"=>"Felix"},{"cat"=>"Felix"}]为什么Ruby会这样做,而不是对object进行dup或clone? 最佳答案 因为那是thedocumenta
一个对象的散列值是什么意思?在什么情况下两个对象具有相同的哈希值??还有说Array|Hash不能是Hashkeys,这个跟对象的hash值有关系,为什么? 最佳答案 对于要存储在HashMap或哈希集中的对象,必须满足以下条件:如果认为两个对象相等,则它们的哈希值也必须相等。如果两个对象不被认为是相等的,那么它们的哈希值应该很可能不同(两个不同的对象具有相同哈希值的次数越多,对HashMap/集合的操作性能就越差)。因此,如果两个对象具有相同的哈希值,则很有可能(但不能保证)它们相等。上面“相等”的确切含义取决于散列方法的实现者。
在Ruby(1.8.X)中为什么Object既继承了内核又包含了内核?仅仅继承还不够吗?irb(main):006:0>Object.ancestors=>[Object,Kernel]irb(main):005:0>Object.included_modules=>[Kernel]irb(main):011:0>Object.superclass=>nil请注意,在Ruby1.9中情况类似(但更简洁):irb(main):001:0>Object.ancestors=>[Object,Kernel,BasicObject]irb(main):002:0>Object.included
在我看来,我正在尝试显示一个对象表,这是我的代码:CategoriesCBB's">然而这是抛出一个错误说:can'tconvertCapabilityBuildingBlockintoArray关系是正确的,错误来self尝试在此处减去数组的第一个对象的行:有什么方法可以忽略数组中的第一个对象来遍历数组吗?谢谢 最佳答案 尝试使用Array.drop-http://www.ruby-doc.org/core/classes/Array.html#M000294 关于ruby-on-ra
所以我一直在努力解决我一直遇到的这个错误,我终于找到了导致它的原因。我一直觉得,当我调用@my_model.save(false)我会跳过我的ActiveRecord验证。事实证明这是部分正确的。我的对象正在保存到数据库中DESPITE我的ActiveRecord验证。我的问题存在是因为我的一个验证在验证过程中修改了一个子模型(这是一个24小时位置的调度应用程序,因此当午餐被保存时,我对照他们保存的那天和第二天检查它们以及确保用户不是指“凌晨2点”表示要上夜类。我的问题是:有没有办法真正跳过我的验证并直接移动到数据库?这是正常的ActiveRecord行为还是我应该更深入地研究我的验证