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

前端之家收集整理的这篇文章主要介绍了了解swift泛型与将参数视为协议或基类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有人可以帮我理解使用泛型而不仅仅使用基类或协议的好处吗?也许我只需要阅读 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.

原文链接:https://www.f2er.com/swift/319240.html

猜你在找的Swift相关文章