Hi,SwiftGG 翻译组启用了新的域名:swiftgg.team今后翻译组的各项活动将会在新域名下开展,不要错过哦!

作者:Erica Sadun,原文链接,原文日期:2017-01-09
译者:星夜暮晨;校对:Crystal Sun;定稿:CMB

Kyle Cardoza 留言给我:「Erica,当您必须处理指向不同类型的 OpaquePointer 值时,为 OpaquePointer 建立一个别名是否是糟糕的代码风格呢?我觉得类型别名让代码读起来更舒服……」

使用类型别名来创建「假型 (pseudotypes)」(而通常类型别名只会重复表述一个类型),可以用来整齐地组织代码。我赞成任何可以强化语义表述和加强可读性的方案。由于 OpaquePointer 并不是泛型,因此我们没办法像 Array<Int> 或者 Set<String> 那样来封装类型的信息。

// 两者的类型都是 `OpaquePointer`,因此没有办法能具体区分这两者
let p1 = OpaquePointer(unsafeMutableRawPtr1)
let p2 = OpaquePointer(unsafeMutableRawPtr2)

构建便利类型别名 (convenience typealias) 可以强调出结构相同、但用法不同的类型之间的区别。这可以区分每个使用点的具体类型,并且提供了内置的「类型注解 (type commentary)」。

typealias OpaqueType1Pointer = OpaquePointer
typealias OpaqueType2Pointer = OpaquePointer

let p1: OpaqueType1Pointer = OpaquePointer(rawPtr1)
let p2: OpaqueType2Pointer = OpaquePointer(rawPtr2)

然而,您可能还会考虑其他的替代方案。如果您打算减少一些类型安全增强方面的开销,那么可以考虑引入一个简单的值类型,将 OpaquePointer 封装起来,就能够使用特定类型的构造器来完成构造了。这里有一个非常粗略的示例:

struct SometypeWrapper {
let opaque: OpaquePointer
init(value: Sometype) {
opaque = OpaquePointer(Unmanaged.passRetained(value).toOpaque())
}
}

你怎么看?类型别名是一个好的选择吗?或者是一个糟糕的做法呢?还是需要构建一个封装呢?请告知您的看法,可以在留言区评论,或者给我发 tweet。

感谢 Mike Ash 的帮助

本文由 SwiftGG 翻译组翻译,已经获得作者翻译授权,最新文章请访问 http://swift.gg

文章目录