我有一个 VehicleModels 框架,其中包含 Car 、Bike 、Plane 等类。
在另一个框架 VehicleInventory 中,我需要在表格中打印自定义描述(特定于第二个框架)。所以我添加了协议(protocol) DescriptableVehicle 和方法 describe() 。
然后我为所有车辆添加了协议(protocol)扩展,例如:
extension Car: DescriptableVehicle {
func describe() -> String {
return "Car: \(self.vin)" // returns formatted vehicle number
}
}
但是,假设已经改变,现在我不会从我的车辆框架中公开具体的类。相反,我公开了诸如 CarProtocol 、BikeProtocol 之类的协议(protocol),因此通常我拥有相同的信息。
问题是我不能再使用协议(protocol)扩展(或者至少不能以那种形式),因为与 类扩展相反的协议(protocol)扩展不能有继承子句。
知道如何解决这个问题而不是过多地修改我的用法吗?
最初,我认为协议(protocol)上的几个 where 子句加上几个强制转换会达成交易,但是如果没有访问类,它就没有帮助。
我也尝试过适配器和类型删除,但要么我使用不当,要么它用于不同的目的。
为了说明问题,我准备了存储库:https://github.com/wedkarz/SwiftProtocolExtensionsProblem
有两个 Playground 。 V1 是我曾经拥有并且正在工作的。
V2 包含我现在拥有的以及我正在努力实现的功能。
在现实生活中,PrivateFramework 类是一个单独的框架和协议(protocol):VehicleProtocol 、CarProtocol 、BikeProtocol 、 PlaneProtocol 是其中的一部分,但 DescriptableVehicle 不是 PrivateFramework 的一部分,所以不能在里面使用。该示例说明了访问具体类型的问题及其扩展的问题。
你可以看到有一些扩展被注释掉了,因为我不能再使用它们了。目标是使 [VehicleProtocol] 的集合以与以前类似的方式打印其内容。
Best Answer-推荐答案 strong>
这能回答你的问题吗?
class PrivateFramework {
private class AbstractVehicle: VehicleProtocol {
var name: String { return "Abstract vehicle name" }
}
private class Car: AbstractVehicle, CarProtocol {
override var name: String { return "Car vehicle name" }
let vin: String = "ABCDEFGH VIN"
}
private class Bike: AbstractVehicle, BikeProtocol {
override var name: String { return "Bike vehicle name" }
let saddle: String = "Comforable saddle name"
}
private class Plane: AbstractVehicle, PlaneProtocol {
override var name: String { return "lane vehicle name" }
let numberOfEngines: Int = 4
}
func produceVehicles() -> [DescriptableVehicle] {
let car = Car()
let bike = Bike()
let plane = Plane()
return [car, bike, plane]
}
}
protocol VehicleProtocol {
var name: String { get }
}
protocol DescriptableVehicle: VehicleProtocol {
func describe() -> String
}
protocol CarProtocol: DescriptableVehicle {
var vin: String { get }
}
protocol BikeProtocol: DescriptableVehicle {
var saddle: String { get }
}
protocol PlaneProtocol: DescriptableVehicle {
var numberOfEngines: Int { get }
}
extension DescriptableVehicle where Self: CarProtocol {
func describe() -> String { return "Car, \(self.name), \(self.vin)" }
}
extension DescriptableVehicle where Self: BikeProtocol {
func describe() -> String { return "Bike, \(self.name), \(self.saddle)" }
}
extension DescriptableVehicle where Self: PlaneProtocol {
func describe() -> String { return "lane, \(self.name), \(self.numberOfEngines)" }
}
let vehicles: [DescriptableVehicle] = PrivateFramework().produceVehicles()
vehicles.forEach { print($0.describe()) }
关于ios - 将类扩展继承子句迁移到协议(protocol)扩展,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/47436106/
|