草庐IT

objc_retain

全部标签

objective-c - 以协议(protocol)为参数的 ObjC 泛型集合被翻译为 [AnyObject]

为什么protocols属性在swift中被翻译成[AnyObject],而不是[P]@protocolP;@classC;@interfaceTestGenerics:NSObject@propertyNSArray*classes;@propertyNSArray*protocols;@end在Swift中它看起来是这样的:publicclassTestGenerics:NSObject{publicvarclasses:[C]publicvarprotocols:[AnyObject]}更新:找到解决方案@propertyNSArray*>*protocols;或者喜欢建议的ne

ios - 如何快速将 void block 传递给 objc_setAssociatedObject

我正在尝试通过扩展向UIView添加点击手势支持。这使用Objective-C非常简单,但是当我尝试在运行时属性上设置void返回block时出现以下错误。error:type'()->Void'doesnotconformtoprotocol'AnyObject'这是计算属性:vartapAction:(()->Void)?{get{objc_getAssociatedObject(self,&AssociatedKeys.SNGLSActionHandlerTapBlockKey)}set{objc_setAssociatedObject(self,&AssociatedKeys.

ios - ld : SDK. 使用旧版本的 Swift 语言 (XX) 编译的框架比以前的 ObjC 框架文件(未知 ABI 版本 YYY)

简介我正在处理SDK.framework,我需要将其作为闭源软件进行分发。为了涵盖objective-c和swift项目,我决定在objective-c上编写它在本地环境中我有两个项目:SDK(框架源代码)DemoApp(链接到SDK.framework的应用)*这些项目在单独的工作空间中问题当我在本地编译SDK.framework时,它运行完美。一旦我从CI获得一个(它有不同的iOSSDK版本)并尝试将它与DemoApp链接我得到这个错误:ld:SDK.frameworkcompiledwitholderversionofSwiftlanguage(4.0)thanpreviousf

ios - 内存管理 : retain cycle with weak var, 无主的非保留周期。为什么?

长话短说我有一个结构和一个类。该结构具有对该类实例的引用,并且该对象具有捕获该结构的闭包。如果对对象的引用是unowned,那么它们似乎都被取消了初始化。如果对对象的引用弱,它们会相互保留。为什么?我有一个可以相互引用的结构和一个类,我试图找出保留循环和打破它们的方法。所以我在playground上玩了一会儿。给定这段代码:structA{unownedvarb:Binit(b:B){self.b=b}funcsetup(){print("Asetup")b.didSomethingClosure={print("A:bdiddosomething")self.printSomethi

objective-c - 转义闭包是如何在 Swift 3 中实现的(底层)?它们是否像在 objective-c 中那样隐式地 block_copied/retained?

我想了解转义闭包在Swift3中是如何工作的?来自Objective-C世界,对于闭包可以逃避其封闭函数返回的场景,您必须按照以下思路做一些事情:@property(nonatomic,copy/strong)void(^callback)(NSData*rawData);-(BOOL)someFunctionThatConsumesABlock:(void(^)(NSData*rawData))block{if(callback){self.callback=block;returnYES;}returnNO;}-(void)someFunctionThatExecutesAtSom

swift - 为什么我可以将 @objc 协议(protocol)声明为弱属性,而不是 swift 协议(protocol)?

我发现如果我创建一个这样的协议(protocol):protocolMyProtocol{}我不能这样做:weakvarmyVar:MyProtocol?我找到了解决这个问题的方法,就是将@objc添加到协议(protocol)声明中:@objcprotocolMyProtocol{}但是为什么这样可以修复错误呢?我的猜测是添加@objc会阻止结构符合协议(protocol),因此变量的值被保证为引用类型。我说得对吗?此外,添加@objc会阻止我添加像[String:Any]这样的swift类型。我也想知道是否有另一种修复错误的方法。 最佳答案

Swift objc_getAssociatedObject 始终为零

我正在尝试将属性关联到数组扩展:privatevarAssociatedObjectHandle:String="BlaBLabla"extensionArray{varemptyIndex:Int{mutatingget{ifletobject=objc_getAssociatedObject(self,&AssociatedObjectHandle){returnobjectas!Int}letindex=self.searchEmptyIndex()self.emptyIndex=indexreturnindex}set{letnew=(newValueasNSInteger)o

ios - 实例方法表单扩展的覆盖取决于 '@objc' 的弃用推理

我正在尝试将我的代码(用Swift3编写)转换为Swift4,为此我在需要的地方添加了@objc。Xcode在自动修复它们方面做得很好,但我正在努力解决一些问题(都使用相同的2种方法),Xcode无法提供帮助,它只是将@objc放在我的代码中的某个地方.我在我的ViewController类中覆盖了一个名为navbarRightButtonAction(button:)的方法。classViewController:PBViewController{overridefuncnavbarRightButtonAction(button:PBAdaptiveButton){...}}这是我

Swift 包管理器和 Xcode : Retaining Xcode Settings?

我正在使用Swift开发服务器并使用Swift包管理器。并且发现在我的MacOS系统上进行开发时生成一个Xcode项目以使用Xcode作为我的IDE很方便(即,有时,我的包依赖项必须更新。我一直在使用swiftpackagegenerate-xcodeproj来执行此操作。此时我的问题出现了——我在Xcode中创建了一些设置。例如,我设置了一个DEBUG标志,并且我有一个.plist文件位于Copy文件阶段。当我重新生成Xcode项目时,这些文件丢失了。看来我不能简单地使用swiftpackageupdate,因为有时文件在依赖项中发生变化,而这些文件不会传播到Xcode项目。我想要的

ios - 不支持覆盖扩展中的非@objc 声明

似乎不知从何而来,我开始收到与我经常使用的两个扩展函数相关的数百个错误。我尝试注释掉出现此错误之前的所有新代码。我还尝试清理我的构建文件夹。我如何摆脱这篇文章标题中发现的错误?为什么我已经成功使用这些扩展几个月了,它却随机出现?extensionUITableViewCell{publicfuncgetSize(large:CGFloat,medium:CGFloat,small:CGFloat)->CGFloat{varsize=CGFloat()letscreenHeight=Int(UIScreen.main.bounds.height)ifscreenHeight>=800{s