Objective-C可以在某种程度上与c ++和can be called to each other混合使用。但Objective-C对象仍然或多或少地手动管理,并且语言中完全没有RAII习语。我想知道是否有可能用c ++智能指针来管理Objective-C对象的生命周期。特别是现在提升scoped_ptr
和shared_ptr
已添加到C ++ 11标准
答案 0 :(得分:14)
但Objective-C对象仍然或多或少地手动管理,并且语言中完全没有RAII习语。
我认为无论如何这似乎都会回答你的问题。因为Objective-C对象是引用计数的,所以它们已经实现了为以下目的创建智能指针的目的:将对象的生命周期与其包含的方法的范围进行离婚或绑定。scoped_ptr
s可以使用autorelease重新创建使用shared_ptr
- -retain
或-release
引用的strong
池。
但是说不,很无聊。如果你真的想要像这样混合Objective-C和C ++,我们首先需要放松“Objective-C对象”的定义。运行时识别出isa
作为第一个成员作为对象的任何东西,我们可以利用它并编写一个带有相应对象接口的简单C ++类,以便可以发送消息:
@interface CFIObject : NSObject
- (void)doSomething;
@end
struct CFIObject_cxx {
Class isa;
public:
CFIObject_cxx() : isa([CFIObject class]) {}
~CFIObject_cxx() { printf("I'm dying!"); }
};
@implementation CFIObject
- (void)doSomething {
NSLog("I did something.");
}
@end
我们现在可以实例化一个C ++对象的实例并将其包装在一个智能指针中,我将故意将其拆分为两个方法来说明对象的生命周期:
void func() {
// Instantiate a smart pointer with our fake object.
std::unique_ptr<CFIObject_cxx> cppObj (new CFIObject_cxx());
id obj = (__bridge id)(cppObj.get());
// The runtime thinks we're an object.
[obj doSomething];
// aaaand, it's out of scope.
}
int main(int argc, const char **argv) {
func();
return 0;
}
正如人们所料,这会打印出来:
2013-12-22 17:23:22.681 Test[77528:303] I did something
I'm dying!
到控制台。
如果需要,可以使用析构函数调用-dealloc
来模拟正确的对象破坏,但我希望你看到所有这些都是完全没必要的,特别是随着每个版本的ARC变得越来越聪明CLANG。