gpt4 book ai didi

ios - Swift 中的协议(protocol)是引用类型还是值类型?

转载 作者:行者123 更新时间:2023-11-28 05:53:21 25 4
gpt4 key购买 nike

我问这个问题的原因是因为我正在阅读使用委托(delegate)的教程。根据我从其他在线教程/文章中阅读的内容,据我所知,该特定教程尚未创建保留周期。我还使用仪器(内存泄漏和僵尸)对其进行了测试,以确保没有内存泄漏。

我想弄清楚一个类是否只是简单地符合一个协议(protocol),这会创建一个引用吗?

我不认为是这样,但我想确定一下。

这是创建委托(delegate)成员的协议(protocol)和类:

import Foundation
import CoreBluetooth

protocol TransferServiceScannerDelegateProtocol: NSObjectProtocol {
func didStartScan()
func didStopScan()
func didTransferData(data: NSData?)
}

class TransferServiceScanner: NSObject, CBCentralManagerDelegate, CBPeripheralDelegate {
var centralManager: CBCentralManager!
var discoveredPeripheral: CBPeripheral?
var data = NSMutableData()
weak var delegate: TransferServiceScannerDelegateProtocol?

init(delegate: TransferServiceScannerDelegateProtocol?) {
super.init()
centralManager = CBCentralManager(delegate: self, queue: nil)
self.delegate = delegate
}


//start of cbCentralDelegate method
func centralManagerDidUpdateState(_ central: CBCentralManager) {
switch central.state {
case .poweredOn:
print("Central is powered on...")
break
case .poweredOff:
print("Central is powered off...")
break
default:
print("Central manager changed state \(central.state)")
break
}
}
//end of cbCentralDelegate method

}

这里是一个 View Controller ,它符合协议(protocol),但也有一个属性 which 是上面提到的类型类。我还不确定为什么这个 View Controller 符合协议(protocol),但我认为这不会增加引用计数:

import UIKit

class CentralViewController: UIViewController, TransferServiceScannerDelegateProtocol {
@IBOutlet var heartImage: UIImageView!
@IBOutlet var scanButton: CustomButton!
@IBOutlet var textView: UITextView!
var transferServiceScanner: TransferServiceScanner!

// MARK: TransferServiceScannerDelegateProtocol methods
func didStartScan() {
//
}

func didStopScan() {
//
}

func didTransferData(data: NSData?) {
//
}
//end of TransferServiceScannerDelegateProtocol methods


override func viewDidLoad() {
super.viewDidLoad()
transferServiceScanner = TransferServiceScanner.init(delegate: self)
}

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


/*
// MARK: - Navigation

// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/

}

最佳答案

I don't think this should increase the reference count:

var transferServiceScanner: TransferServiceScanner 将引用计数增加到 1,因为如果没有声明为弱引用或其他引用,所有引用都是强引用。

将委托(delegate)变量存储为 weak 可确保强引用不会双向传递,因此 ARC 可以取消初始化它们。

I'm trying to figure out if a class were to simply conform to a protocol, does this create a reference?

类始终是引用类型,无论您是通过协议(protocol)还是直接引用它。因此,为协议(protocol)分配其背后的引用类型(类)不会复制类对象,但您宁愿提供对该对象的另一个引用并增加 ARC 查看的引用计数。

protocol TransferServiceScannerDelegateProtocol: NSObjectProtocol {

您确定只有一个类可以实现该协议(protocol),这就是为什么您可以声明 weak var delegate: TransferServiceScannerDelegateProtocol,因为只有类可以实现 NSObjectProtocol NSObject & co.

在不声明协议(protocol)仅类的情况下,无论是结构还是类,都可以实现协议(protocol)。但只有当您将协议(protocol)限制为仅类时,您才能像使用类一样使用该协议(protocol),并使用 weak 之类的东西。

关于ios - Swift 中的协议(protocol)是引用类型还是值类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52139013/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com