Replace Method with Method Object
概述
将这个函数放进一个单独对象中,如此一来局部变量就成了对象内的值域(field),然后你可以在同一个对象中将这个大型函数分解为数个小型函数.
动机(Motivation)
小型函数优美动人,只要将相对独立的代码从大型函数中提炼出来,就可以大在提高代码的可读性.
示例
1 |
public int Gamma( int inputValue, int quantity, int yearToDate) |
3 |
int importantValue1 = inputValue * quantity + DateTime.Now.Minute; |
4 |
int importantValue2 = inputValue * yearToDate + 100; |
5 |
if ((yearToDate - importantValue1) > 100) |
7 |
int importantValue3 = importantValue2 * 7; |
8 |
return importantValue3 - 2 * importantValue1; |
改为
01 |
private int importantValue1; |
02 |
private int importantValue2; |
03 |
private int importantValue3; |
05 |
public int Gamma( int inputValue, int quantity, int yearToDate) |
07 |
importantValue1 = inputValue * quantity + DateTime.Now.Minute; |
08 |
importantValue2 = inputValue * yearToDate + 100; |
09 |
ImportantThing(yearToDate); |
10 |
importantValue3 = importantValue2 * 7; |
11 |
return importantValue3 - 2 * importantValue1; |
14 |
private void ImportantThing( int yearToDate) |
16 |
if ((yearToDate - importantValue1) > 100) |
17 |
importantValue2 -= 20; |
Substitute Algorithm(替换你的算法)
概述
将函数本体(method body)替换为另一个算法。
动机(Motivation)
如果你发现做一件事可以有更清晰的方式,就应该以较清晰的方式取代复杂方式。可以把一些复杂的东西分解为较简单的小块,但有时你就是必须壮士断腕,删掉整个算法,代之较简单的算法。
示例
01 |
public string FoundPerson( string [] people) |
03 |
for ( int i = 0; i < people.Length; i++) |
05 |
if (people[i].Equals( "Don" )) |
09 |
if (people[i].Equals( "John" )) |
13 |
if (people[i].Equals( "Kent" )) |
改为
01 |
public string FoundPerson( string [] people) |
03 |
List< string > candidates = new List< string >() { "Don" , "John" , "Kent" }; |
04 |
for ( int i = 0; i < people.Length; i++) |
06 |
if (candidates.Contains(people[i])) |
总结
小型函数优美动人,用较清晰方式取代复杂方式,易于阅读