结构上的Swift扩展使私有初始化保护变得不可能

MH1*_*175 5 swift

在Swift中,您可以通过将初始化程序设为私有来防止对象直接初始化.您可能希望使用Factory模式执行此操作.

但是,如果您创建扩展,您可以提供不同的初始化程序并进行编译.扩展名是否在同一文件中并不重要.例如,如果您的工厂方法执行某些数据验证,则可能会产生严重后果.

我错过了一些私人信息吗?这看起来非常糟糕.我可以阻止这个吗?

struct Foo {

    let data: Int

    // factory method
    static func makeFoo(data: Int) -> Foo {
        return Foo(data: data)
    }

    // private init with data validation
    private init(data: Int) {
         guard data < 100 else {
            fatalError("Foo should only have values under 100")
         }
        self.data = data
    }
}

extension Foo {
    init(someData: Int) {
        // This bypasses the data validation and puts Foo into an invalid state.
        self.data = someData
    }
}
Run Code Online (Sandbox Code Playgroud)

MH1*_*175 2

根据上面 zneak 的评论,这在 Swift 5 中是不允许的。