加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-14 02:24:00 所属栏目:百科 来源:网络整理
导读:我对 Swift和一般编程非常陌生,有点像Fortran 77,以及最近一些简单的微控制器编程.我正在研究基础知识,一切顺利,直到我遇到了一些我无法理解的事情 – 代表们.所有的在线帖子都没有完全理解这个概念,至少对我而言,所以为了给自己一些我可以参考的东西,我在操
我对 Swift和一般编程非常陌生,有点像Fortran 77,以及最近一些简单的微控制器编程.我正在研究基础知识,一切顺利,直到我遇到了一些我无法理解的事情 – 代表们.所有的在线帖子都没有完全理解这个概念,至少对我而言,所以为了给自己一些我可以参考的东西,我在操场上设置了如下所示的基本模板.如果我运行下面的代码它工作并打印“完成的东西”到终端,但如果我使协议成为“类”协议,即“协议SomeDelegate:class {”并使“var委托”成为“弱var委托”按照各种帖子的建议,它不起作用 – 我做错了什么?
import UIKit

protocol 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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读