发现自己有一个编程习惯,正在努力让自己戒掉,这个习惯是像下面这样的:
switch something { 把一些复杂的绑定值定义到 case 中 case: // ...用绑定值做一些事 default: break }
这里有个真实的例子:
enum Tree<T> { case empty indirect case node(value: T,left: Tree<T>,right: Tree<T>) func show(indent: Int = 0) { switch self { case let .node(value: value,left: left,right: right): print(String(repeating: " " as Character,count: indent),value) right.show(indent: indent + 4) left.show(indent: indent + 4) default: break } } }
我尝试打破这个模式是因为有个更简单的方式来实现,那就是用 if case
来代替 switch
。只有一种 case 需要考虑,默认情况下不需要做任何操作。
经过重构后,产生了下面简化后的代码,使所有的绑定和与 .node
相关的行为产生关联,来被压缩放置到一起。
enum Tree<T> { case empty indirect case node(value: T,right: Tree<T>) func show(indent: Int = 0) { if case let .node(value: v,left: l,right: r) = self { print(String(repeating: " " as Character,v) r.show(indent: indent + 4) l.show(indent: indent + 4) } }
在很多情况下,我通常会鼓励自己使用 switch
或是 guard
,而不是 if
来明确我的意图并增加可读性,但是在这个例子上最好还是用回经典的 if 吧。
本文由 SwiftGG 翻译组翻译,已经获得作者翻译授权,最新文章请访问 http://swift.gg。