我希望从MKMapItem返回的MKLocalSearch包含一个“高度”属性。为了实现这一点,我决定为MKMapItem创建一个子类。
class MapItemGeoSpatial: MKMapItem {
var altitude: Measurement<UnitLength>
public init(placemark: MKPlacemark, altitude: Measurement<UnitLength>) {
self.altitude = altitude
super.init(placemark: placemark)
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}当上面的实现编译时,它在尝试初始化MapItemGeoSpatial时会导致一个致命的错误。
Fatal error: Use of unimplemented initializer 'init()' for class 'MapItemGeoSpatial'上述错误发生在super.init(placemark: placemark)调用过程中。
我可以为上面的类创建一个override init(),但是这需要我初始化altitude属性,这个属性不是为这个初始化器指定的。通过指定虚拟变量初始化altitude (例如。( 0)克服了这个问题,但似乎是一个糟糕的解决办法。使altitude可选是另一个解决办法,但这不是我想要采取的方向。
我知道MKMapItem是从NSObject继承来的,我很好奇这种关系是否对上面的观察有影响。我想了解这个问题背后的根本原因;( ii)确定子类MKMapItem是否是本文开头提到的问题的可行解决方案。
发布于 2022-08-11 00:40:19
@matt的评论建议将MKMapItem包装起来,这是解决最初问题的可行方法。
对于那些对坠机原因感兴趣的人,我在苹果开发者论坛上发布了同一个问题,其中一个评论提出了一个潜在的原因。我会在这篇文章中总结一下。
下图表示Swift中初始化过程的一般概况(有关更多信息,请参见类继承和初始化 )。请注意,指定的初始化程序不能从超类中调用方便的初始化符。

对目标C对象进行子类划分的过程(如。然而,MKMapItem(在Swift中)并没有遵循上述约定。特别是-
MapItemGeoSpatial从最初的问题不满足要求从上面的第二点继承超类初始化。此外,MKMapItem.init(placemark:)似乎是一个方便的初始化器,因为它在内部调用MKMapItem.init() (参见关于为什么MapItemGeoSpatial可以从指定的初始化器调用它的第1点)。
下面的图表试图可视化上面的内容。

免责声明
我没有使用目标C,我在语言上也没有一个很好的基础。上述调查结果是根据从指定资源收集的意见和资料得出的。如果有人能更好地理解目标-C和Swift,我将不胜感激,提供一个更详细的解释或说明任何更正。
https://stackoverflow.com/questions/72037393
复制相似问题