calayer – 无法在Swift中释放由CGPathCreateMutable创建的路径
发布时间:2020-12-14 04:47:16 所属栏目:百科 来源:网络整理
导读:我在 Swift中有这个简单的代码: override var bounds : CGRect { didSet { if (bounds != oldValue) { var path = CGPathCreateMutable() CGPathAddEllipseInRect(path,nil,bounds) self.path = path CGPathRelease(path) } }} 当图层的边界发生变化时,它应
我在
Swift中有这个简单的代码:
override var bounds : CGRect { didSet { if (bounds != oldValue) { var path = CGPathCreateMutable() CGPathAddEllipseInRect(path,nil,bounds) self.path = path CGPathRelease(path) } } } 当图层的边界发生变化时,它应该绘制一个填充图层的圆. 这是从我的旧Objective-C代码移植而来的,它运行正常: - (void)setBounds:(CGRect)bounds { if (CGRectEqualToRect(self.bounds,bounds)) return; super.bounds = bounds; CGMutablePathRef path = CGPathCreateMutable(); CGPathAddEllipseInRect(path,bounds); self.path = path; CGPathRelease(path); } 但是,Swift代码崩溃了一些段错误.如果我不释放路径,那很好.如果我没有设置self.path = path,它也没关系(虽然没有任何东西会显示出来).如果两者都存在,它将崩溃. 我确实认为CGPathCreateMutable()创建的路径需要释放..而ObjC似乎就是这种情况.有谁知道为什么它在Swift中不起作用?或者我做错了什么? 谢谢! 解决方法
您不需要在Swift中释放CF对象.在您的情况下,CGPathCreateMutable()返回一个CGPath对象(不是CGPathRef),并且内存管理与任何swift对象相同.他们在WWDC视频
Swift Interoperability In Depth中对此进行了解释
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |