Swift associatedtype

2020-09-08  本文已影响0人  gaookey

在协议中除了定义属性和方法外,我们还能定义类型的占位符,让实现协议的类型来指定具体的类型。

protocol Food { }

protocol Animal {
    associatedtype F: Food
    func eat(_ food: F)
}

struct Meat: Food { }
struct Grass: Food { }

struct Tiger: Animal {
    func eat(_ food: Meat) {
        print("eat \(food)")
    }
}

struct Sheep: Animal {
    func eat(_ food: Grass) {
        print("eat \(food)")
    }
}

Tiger().eat(Meat())
Sheep().eat(Grass())

添加 associatedtype 后,Animal 协议就不能被当作独立的类型使用了。因为 Animal 包含了一个不确定的类型,所以随着 Animal 本身类型的变化,其中的 F 将无法确定。在一个协议加入了像是 associatedtype 或者 Self 的约束后,它将只能被用为泛型约束,而不能作为独立类型的占位使用。我们需要将函数改写为泛型:

func isTiger<T: Animal>(animal: T) -> Bool {
    if animal is Tiger {
        return true
    } else {
        return false
    }
}

//true
isTiger(animal: Tiger())
//false
isTiger(animal: Sheep())

摘录来自: 王巍 (onevcat). “Swifter - Swift 必备 Tips (第四版)。”

上一篇 下一篇

猜你喜欢

热点阅读