多少祸端起于觊觎别人的生活.
位移枚举
目录
问题引入
假定有一项考试,考试内容为辨别左、右两个方向,辨认正确得一分.写出考试和得分方法.
问题解析
|
|
上述为最直接的方法,先调用辨认方向的方法,后查看成绩.
如果此时左、右代表两大块;左细分为左上,正左,左下;同理,右细分为右上,正右,右下.并且左上,左下, 右上,右下,辨认分值为2分.
那此时,recognizeLeft
, recognizeRight
各自变换成细分的三个方法,虽然能解决,但需要增加很多辨认方法,不是一个好的解决方式.
此时,把左(isLeft),右(isRight) 从BOOL值,转成枚举值,可解决上面问题.
|
|
原来的recognizeLeft
, recognizeRight
修改:
|
|
这样,当辨认左上方时,若能辨认则传LeftTypeTop
,不能则传LeftTypeUnknown
或不调用该方法.其他各方向同理.这样存在的问题是,虽然方法数没增加,但是调用次数增多了.
下面,引入位移枚举的方法讲解.
概念讲解
位移枚举的定义:
|
|
问题解决办法(位移枚举)
|
|
|
|
这样,我们调用的时候,就可以先赋值好枚举变量,调用辨认方法就可以了.
|
|
还是需要调用左,右两个方法,有了位移枚举,可以合并成一个方法.
优化方法
左、右枚举,合并
|
|
辨认方法合并
|
|
调用方法:
|
|