草庐IT

self-center

全部标签

swift - Swift 闭包中的 `self`

我想在Swift闭包中理解self。例如-()->Void={[weakself]inguardlet`self`=selfelse{self.callMethod2()}self.callMethod3()}为什么我们在这里使用反引号?这是好的编程习惯吗?self是如何弱捕获到这里的? 最佳答案 Swift4.2最近采纳了一项将此添加到语言中的提案:guardletself=selfelse{return}所提出的解决方案需要允许使用可选绑定(bind)将self从弱引用升级为强引用。更多细节引用swiftevolutionpro

objective-c - 有没有办法显示不使用弱 self 的警告?

每隔几个月,我都会遇到同样的问题,即ViewController没有被释放,因为没有在block中使用weak-self。有什么方法可以让Xcode警告我吗?谢谢。 最佳答案 这可能有助于-Warc-retain-cycles此外,如果您在Xcode中选择分析而不是构建,这将为您提供有关代码中不良做法的更多信息,其中包括有关使用弱变量的信息。另一个层次是使用Infer,Facebook开源的iOS/Android静态分析器:www.fbinfer.com另请参阅:http://fuckingclangwarnings.com/对于其

ios - Game Center 邀请立即失败

我们在使用GKGameCenterViewController发送邀请时遇到问题。ViewController打开得很好,但是当我们尝试向某人发送邀请时,它立即失败了。这两个帐户都启用了游戏中心邀请,并且可以通过GKGameViewController找到其他玩家。这是我们用来管理邀请的代码:一旦GKLocalPlayer被验证(验证从GameViewController调用,此代码在单独的GameCenter管理类中),就会调用此方法:internalfuncauthenticationChanged(){ifGKLocalPlayer.localPlayer().authentic

swift - 什么是 objc_sync_exit(self)

我看到在UISearchBarDelegate方法textDidChange中使用了这个函数。我到处寻找任何文档,但无法提出任何建议。只是想知道是否有人可以阐明此功能的作用。objc_sync_exit(self) 最佳答案 当您编写同步代码以停止某项运行多次(Objective-C:“@synchronized”)时,它会在幕后转换为对objc_sync_enter()和objc_sync_exit()的调用。如果您看到有人直接使用这些函数,这表明他们不能使用普通的旧同步块(synchronizedblock)(或他们自己的Swi

ios - Swift- 错误 : Variable 'self.___' used before being initialized

我正在尝试在Playground中使用手势识别器,但遇到了一些问题。这是我的类(class):classfoo{varfooVarSwipe:AnyvarfooVarTap:Anyinit(){letgr=UISwipeGestureRecognizer(target:self,action:#selector(foo.bar))lettr=UITapGestureRecognizer(target:self,action:#selector(foo.tar))helloApple.addGestureRecognizer(gr)helloApple.addGestureRecogni

Swift:在初始化程序中多次调用 Self.init

这个让我难住了。我不明白为什么Swift提示self.init在这段代码中被多次调用:publicinit(body:String){letparser=Gravl.Parser()ifletnode=parser.parse(body){super.init(document:self,gravlNode:node)}else{//Swiftcomplainswiththementionederroronthisline(itdoesn'tmatterwhat"whatever"is):super.init(document:self,gravlNode:whatever)}}除非我

ios - Swift 函数范围 - 引用 self (意味着 "self as the enveloping function")

采用这个基本函数:funcsampleFunction(){print(self)}这里self指的是包含它的class实例,而不是-可能更有意义-包含它的function.如何获取对封装函数而不是其封装类实例的引用?理想情况下,我希望做这样的事情:funcsampleFunction(value:Int){print(selfAsEnvelopingSampleFunction,value)} 最佳答案 如果要打印函数名,可以使用__FUNCTION__print(__FUNCTION__)在您的print语句中,否则只需使用sa

ios - 自定义 UIView 初始化程序的便利初始化程序必须使用 self.init 错误进行委托(delegate)

我正在尝试为UIView创建自定义初始化方法,如下所示:convenienceinit(frame:CGRect,tutorProfileImageURL:String?){self.tutorProfileImageURL=tutorProfileImageURLsuper.init(frame:frame)}overrideinit(frame:CGRect){super.init(frame:frame)setup()}requiredinit?(coderaDecoder:NSCoder){super.init(coder:aDecoder)setup()}funcsetup(

swift UIStackView : Positioning elements from center programmatically

我正在尝试让UIStackView中的元素从中心平等定位。这是我想要的效果:如您所见,我希望两个文本字段彼此等距并在堆栈View中居中对齐。此堆栈View将有1-7个我需要排列的文本字段。这是目前发布的内容:这就是我设置文本字段的方式lettextLabel=UILabel()textLabel.backgroundColor=UIColor.redtextLabel.widthAnchor.constraint(equalToConstant:40.0).isActive=truetextLabel.heightAnchor.constraint(equalToConstant:20

swift - 如何实现返回协变 Selfs 的协议(protocol)方法?

错误:非最终类(“Class”)无法满足协议(protocol)“Protocol”要求“instance”,因为它在非参数、非结果类型位置使用“Self”protocolProtocol{varinstance:Self{get}}classClass:Protocol{varinstance:Class{returnSubclass()}}classSubclass:Class{}以下是我在C#中表达我想要的内容的方式。(据我所知,C#没有办法强制通用参数“Self”实际上是我们从Swift中知道的Self,但它作为文档足以让我做正确的事情。)interfaceProtocolwh