简单快捷的代表在快速的 *** 场上

简单快捷的代表在快速的 *** 场上,第1张

概述我对 Swift和一般编程非常陌生,有点像Fortran 77,以及最近一些简单的微控制器编程.我正在研究基础知识,一切顺利,直到我遇到了一些我无法理解的事情 – 代表们.所有的在线帖子都没有完全理解这个概念,至少对我而言,所以为了给自己一些我可以参考的东西,我在 *** 场上设置了如下所示的基本模板.如果我运行下面的代码它工作并打印“完成的东西”到终端,但如果我使协议成为“类”协议,即“协议SomeDe 我对 Swift和一般编程非常陌生,有点像Fortran 77,以及最近一些简单的微控制器编程.我正在研究基础知识,一切顺利,直到我遇到了一些我无法理解的事情 – 代表们.所有的在线帖子都没有完全理解这个概念,至少对我而言,所以为了给自己一些我可以参考的东西,我在 *** 场上设置了如下所示的基本模板.如果我运行下面的代码它工作并打印“完成的东西”到终端,但如果我使协议成为“类”协议,即“协议SomeDelegate:class {”并使“var委托”成为“弱var委托”按照各种帖子的建议,它不起作用 – 我做错了什么?
import UIKitprotocol SomeDelegate {    func DoSomething()}class MyVIEwcontroller: UIVIEwController,SomeDelegate {    func DoSomething() {        print("Something done")    }}class OtherClass {   var delegate: SomeDelegate?    func DoSomething() {        delegate?.DoSomething()    }}var myVar = OtherClass()myVar.delegate = MyVIEwcontroller()myVar.DoSomething()
它不会打印,因为委托在您设置后就是零.原因很简单:没有实例拥有它(引用计数为零).没有人拥有委托,因为你声明它是OtherClass的弱属性.尝试建立所有权,例如
var myVar = OtherClass()let vIEwController = MyVIEwController()myVar.delegate = vIEwController

虽然代表很弱,但它现在会再打印一些东西.

将委托声明为弱是有道理的,因为它可以防止循环引用导致委托永远不会在内存中释放 – 这是一个完全不同的故事 – 检查引用计数的工作方式,然后你就会明白为什么这是一个好的做法.

总结

以上是内存溢出为你收集整理的简单快捷的代表在快速的 *** 场上全部内容,希望文章能够帮你解决简单快捷的代表在快速的 *** 场上所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1089320.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存