swift 如何从第二个 vai 协议和委托模式中的逻辑更新第一个控制器?

swift how to update first controller from logic in second one vai protocol and delegate pattern?

我在第一个视图控制器中有一个标签 ViewController,在第二个 vc 中有一个每秒获取日期的函数。我想在计时器第二次启动后首先更新标签。使用协议委托模式好吗?目前它不工作,时间在流逝,但首先没有更新视图 VC

我的协议结构

protocol ViewControllerDelegate: class {        
    func changeLabelText(textToPass: String)        
}

第一viewController

class ViewController: UIViewController, ViewControllerDelegate {


    @IBOutlet weak var mainLabel: UILabel!        

    override func viewDidLoad() {
        super.viewDidLoad()    
    }


    func changeLabelText(textToPass: String) {
        self.mainLabel.text = textToPass
        self.view.layoutIfNeeded()
    }

    @IBAction func buttonTapped(_ sender: UIButton) {            

        let nextVC = storyboard?.instantiateViewController(withIdentifier: "SecondViewController") as! SecondViewController
        nextVC.delegateSubscriber = self            
        present(nextVC, animated: true, completion: nil)            
    }

}

秒VC

class SecondViewController: UIViewController {

    //MARK: speed timer feature 1/3
    private weak var timer: Timer?
    private var timerDispatchSourceTimer : DispatchSourceTimer?

    weak var delegateSubscriber : ViewControllerDelegate?       

    @IBOutlet weak var myTxtField: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()            
        startTimer(every: 1)            
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)

        print("appeared")
        stopTimer()

    }

    private func startTimer(every timeInterval: TimeInterval) {
        if #available(iOS 10.0, *) {
            timer = Timer.scheduledTimer(withTimeInterval: timeInterval, repeats: true) { [weak self] _ in

                let dateToPass = Date().description
                print(dateToPass)
                self?.delegateSubscriber?.changeLabelText(textToPass: dateToPass)

            }
        }
    }

    //MARK: speed timer feature 3/3
    private func stopTimer() {
        timer?.invalidate()
        //timerDispatchSourceTimer?.suspend() // if you want to suspend timer
        timerDispatchSourceTimer?.cancel()
    }

    @IBAction func buttonTapped(_ sender: UIButton) {

//        delegateSubscriber?.changeLabelText(textToPass: self.myTxtField.text ?? "error")

        dismiss(animated: true, completion: nil)
    }        
}

只需从 Timer 闭包中删除 [weak self]

timer = Timer.scheduledTimer(withTimeInterval: 1, repeats: true) { _ in
    let dateToPass = Date().description
    print(dateToPass)
    self.delegateSubscriber?.changeLabelText(textToPass: dateToPass)
}

...那么self不是可选的