class myClass: NSObject { var model = "UnspecifIEd" overrIDe init() { super.init() var key: Nsstring = "model" var aClass : AnyClass? = self var ivar: Ivar = class_getInstanceVariable(aClass,key.UTF8String) // Set object_setIvar(aClass,ivar,"R56") // Get var value: AnyObject = object_getIvar(aClass,ivar) }}myClass()解决方法 你得到一个糟糕的访问权限,因为Swift类不再拥有传统的iVars了(尝试抓住Swift类的’iVar布局并亲自看看).但Swift类也是运行时的Objective-C对象,并且似乎没有任何路径排除Swift类.
最后发生的事情是运行时将你伪造成iVar,它真正认为指向类定义中的适当偏移(可能是0或左右,因为它不存在).当你试图说iVar时,运行时字面意思是derefs you some of the object’s bytes and tries to wrap it back up in an Objective-C pointer.通常这个数据会无意中设置标记位,因此经常映射到标记类(在我的测试中,我可靠地找回运行时认为是NSMutableData的标记指针) .
长话短说:你不能再这样做了.
总结以上是内存溢出为你收集整理的如何在swift中使用objective-c-runtime的object_getIvar和object_setIvar?全部内容,希望文章能够帮你解决如何在swift中使用objective-c-runtime的object_getIvar和object_setIvar?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)