我搜索了很多东西,却没有发现任何真正有助于解决我的问题的东西...

我试图从头开始构建一个简单的UIControl,如UIButton。由于特定原因,它不能是UIControl的子类。

我需要此控件来执行以下操作:

myControl.addTarget(target: AnyObject?, action: Selector, forControlEvents: UIControlEvents)

问题在于,当触摸按钮时执行此选择器的方法的实现需要“performSelector:”方法。

Swift没有“performSelector:”。所以我教了它可以使用闭包来实现。

我不知道如何捕获要在闭包内部修改的对象。
而且我不确定我将如何处理参考周期和类似的事情。

我什至不知道我是否走上了成功的道路。我相信你们可以让我走上正确的轨道!

我来自巴西,对不起我的英语不好!谢谢! :D

这是到目前为止的东西...
struct ClosureForEvent {
    var closure:(control:MyControl!)->()
    var event:UIControlEvents
}

class MyControl {
     private var closures:[ClosureForEvent]?

     init() {}

     func addClosureFor(event:UIControlEvents, closure:(control:MyControl!)->()) {

          if closures == nil {
              closures = [ClosureForEvent(closure: closure, event: event)]
          }
          else {
              closures!.append(ClosureForEvent(closure: closure, event: event))
          }
      }


      func executeClosuresOf(event:UIControlEvents) {
          if closures != nil {
              for closure in closures! {
                  if closure.event == event {
                      closure.closure(control: control)
                  }
              }
          }
      }
  }

  class Test {
       var testProperty = "Default String"

       init() {
            let control = MyControl()
            control.addClosureFor(UIControlEvents.TouchUpInside, closure: { (control) -> () in
            self.testProperty = "This is making a reference cycle?"
            })
       }
  }

最佳答案

就您当前的情况而言,似乎没有形成循环引用。但是将来可能会偶然形成。类似于以下实例。

// In the `Test` class.
let control = MyControl()
init() {
    control.addClosureFor(UIControlEvents.TouchUpInside, closure: { (control) -> () in
        self.testProperty = "This is making a reference cycle?"
    })
}

在此代码中,self对其字段的引用是control,而control通过self添加的闭包引用了addClosureFor。这形成了循环引用,因此循环中的这些对象从不释放。

关闭捕获列表可以解决此问题。
control.addClosureFor(UIControlEvents.TouchUpInside) { [weak self] /* <-- */ control -> () in
    // Here, `self` is visible as `Optional<Test>` so the `?` operator is required.
    self?.testProperty = "This is making a reference cycle?"
    return
}

在上面的代码块中,self被弱捕获,因此从selfcontrol仅形成一个单向引用。
请注意,现在在闭包中,由于对self的引用很少,因此不能保证可以访问self。您必须考虑self为可选值。

https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/AutomaticReferenceCounting.html

关于ios - Swift选择器和闭包讨论,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28778010/

10-12 03:35