首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Swift 中的抽象类型和方法

因为我们不希望这个类被直接使用,所以我们要让它在基类的实现被错误调用时触发一个fatalError: class Loadable { func load(from url: URL...) async throws -> Model { fatalError("load(from:) has not been implemented") } } 然后,每个Loadable...不过,协议确实比抽象类有一个显着的优势,因为编译器将强制它们的所有需求都得到正确实现——这意味着我们不再需要依赖运行时错误(例如 fatalError)来防止不当使用,因为我们无法实例化协议。...networking self.cache = cache } func load(from url: URL) async throws -> Model { fatalError...如果我们仔细想想,基于抽象类的方法唯一真正的问题是,我们必须在每个子类需要实现的方法中加入fatalError,那么如果我们只为这个特定的方法使用一个协议呢?

75620

Swift 中的抽象类型和方法

因为我们不希望这个类被直接使用,所以我们要让它在基类的实现被错误调用时触发一个fatalError: class Loadable { func load(from url: URL...) async throws -> Model { fatalError("load(from:) has not been implemented") } } 然后,每个Loadable...不过,协议确实比抽象类有一个显着的优势,因为编译器将强制它们的所有需求都得到正确实现——这意味着我们不再需要依赖运行时错误(例如 fatalError)来防止不当使用,因为我们无法实例化协议。...networking self.cache = cache } func load(from url: URL) async throws -> Model { fatalError...如果我们仔细想想,基于抽象类的方法唯一真正的问题是,我们必须在每个子类需要实现的方法中加入fatalError,那么如果我们只为这个特定的方法使用一个协议呢?

72420
领券