gpt4 book ai didi

swift - 约束类型别名不使用约束

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

这个有效:

protocol Walkable {
init()
}

class Animal {
init(someProperty: Int) {}
}

class WalkableAnimal: Animal, Walkable {
required init() {
super.init(someProperty: 0)
}
}

class Person {
init() {
InitializeAWalkableAnimal(walkableAnimal: WalkableAnimal.self)
}

func InitializeAWalkableAnimal<T: Animal>(walkableAnimal: T.Type) where T: Walkable {
let animal = walkableAnimal.init()
}
}

但是,我想完全避免使用 WalkableAnimal 子类。我只想创建一个继承自 Animal 并符合 Walkable 协议(protocol)的 Cat class。此外,我无法将 Cat 作为参数直接传递,因为类型是动态的。我希望这样的事情应该有效:

protocol Walkable {
init()
}

class Animal {
init(someProperty: Int) {}
}

class Cat: Animal, Walkable {
required init() {
super.init(someProperty: 0)
}
}

class Dog: Animal, Walkable {
required init() {
super.init(someProperty: 1)
}
}

typealias AnyWalkableAnimal = (Animal & Walkable).Type

class Person {
init(anyWalkableAnimal: AnyWalkableAnimal) {
// ERROR
InitializeAWalkableAnimal(walkableAnimal: anyWalkableAnimal.self)
}

func InitializeAWalkableAnimal<T: Animal>(walkableAnimal: T.Type) where T: Walkable {
let animal = walkableAnimal.init()
}
}

class PersonCaller {
init() {
Person(anyWalkableAnimal: Cat.self)
Person(anyWalkableAnimal: Dog.self)
}
}

错误是:

Instance method 'InitializeAWalkableAnimal(walkableAnimal:)' requires that 'Animal' conform to 'Walkable'

这是无稽之谈,因为 typealias 不允许不是 Walkables 的类型,对吗?为什么编译器不高兴?有什么方法可以传递任何符合 AnimalWalkable 的类型吗?为什么 typealias 不起作用? typealias 明确提到它采用的类型必须是 AnimalWalkable。它以相反的方式工作(如预期的那样):当我尝试传入不符合 WalkableAnimal 时,初始化程序会出现编译错误。

如果有任何不同,我将在 2018 年 12 月 25 日使用 Swift 开发工具链进行开发。

最佳答案

我完全不明白为什么 InitializeAWalkableAnimal 需要通用。

protocol Walkable {
init()
}

class Animal {
init(someProperty: Int) { }
}

class Cat: Animal, Walkable {
required init() { super.init(someProperty: 0) }
}

class Dog: Animal, Walkable {
required init() { super.init(someProperty: 1) }
}

typealias Pet = Animal & Walkable
typealias PetType = Pet.Type

class Person {
init(petType: PetType) {
initPet(petType: petType)
}

func initPet(petType: PetType) {
let pet = petType.init()
print("I got a pet: \(pet)")
}
}

class PersonCaller {
init() {
Person(petType: Cat.self)
Person(petType: Dog.self)
}
}

_ = PersonCaller()

输出:

I got a pet: __lldb_expr_8.Cat
I got a pet: __lldb_expr_8.Dog

关于swift - 约束类型别名不使用约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54560988/

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