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

了解swift泛型与将参数视为协议或基类型

发布时间:2020-12-14 05:27:19 所属栏目:百科 来源:网络整理
导读:有人可以帮我理解使用泛型而不仅仅使用基类或协议的好处吗?也许我只需要阅读 Swift指南几次,但泛型的概念并没有下沉.考虑使用泛型的这个例子 func removeObjectT : Equatable(object: T,inout fromArray array: [T]) { var index = find(array,object) arra
有人可以帮我理解使用泛型而不仅仅使用基类或协议的好处吗?也许我只需要阅读 Swift指南几次,但泛型的概念并没有下沉.考虑使用泛型的这个例子
func removeObject<T : Equatable>(object: T,inout fromArray array: [T]) 
{
    var index = find(array,object)
    array.removeAtIndex(index!)
}

为什么不这样写呢?

// As pointed out,this does not compile. I was more-so curious as to why
func removeObject(object: Equatable,inout fromArray array: [Equatable]) 
{
    var index = find(array,object)
    array.removeAtIndex(index!)
}

谢谢你的解释.

更新.是的,澄清我的例子完全是假设的.我正在考虑如何在Objective-C中实现这个问题.在那,我只是传递类型id的参数,这将做到这一点.

我的问题是为了深入了解为什么Swift中不允许使用类似的模式,而是使用泛型来代替.

在协议的情况下,它取决于协议本身.如果协议使用Self或typealias,则不能直接使用.对于任何其他协议,您可以声明协议< MyProtocol>类型的变量和参数,例如,var o:protocol< MyProtocol>.

你不能说var o:protocol< Equatable>的原因是因为Equatable协议的设计方式必须满足它声明的某些约束(在本例中为Self),因此它只能用作泛型类型约束.换句话说,编译器必须能够在编译时弄清楚Self是关于Equatable的任何东西,并且它不能(总是)在var o:protocol< Equatable>中做到这一点.

为什么使用泛型而不是协议或基类?因为泛型可以比那些仍然是类型安全的更普遍.这特别有用,回调之类的东西.这是一个非常人为的例子:

class Useless<T> {
    private let o: T
    private let callback: (T,String) -> Void
    required init(o: T,callback: (T,String) -> Void) {
        self.o = o
        self.callback = callback
    }
    func publish(message: String) {
        callback(o,message)
    }
}

var useless = Useless(o: myObject) { obj,message in
   // Here in the callback I get type safety. 
   obj.someMethod(message)
}

(此代码从未被任何人运行过.它应被视为伪代码.)

现在,由于很多原因,这是一个非常愚蠢的例子,但它说明了这一点.由于泛型,回调的obj参数完全是类型安全的.这无法通过基类或协议来完成,因为我们永远无法预测回调中可能会调用哪些代码.无用类可以采用任何类型作为其T.

(编辑:李大同)

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

    推荐文章
      热点阅读