第七章 把控制流变得易读

2014-07-05  本文已影响0人  春晓

## 第七章 把控制流变得易读

### 1.条件语句中的参数的顺序

比较的左侧放置倾向于变化的,比较的右侧是放置不变化的

```

if(age > 18) 比 if(18 < age) 更加清晰

```

### 2.if/else语句块的顺序

虽然if/else语句的顺序可以随意调换,但是遵循下面的规则会使代码更加清晰:

- 首先处理正逻辑,不先处理负逻辑。如if(debug) 好于 if(!debug)。

- 先处理简单的逻辑。

- 先处理有趣或者可疑的情况。

### 3.避免使用三目运算符

所有的三目运算符形式都可以写成if/else形式。

**关键思想:只有当最简单的情况可以使用三目运算符。**

### 4.避免使用do、while循环

### 5.从函数中提前返回

编写如下代码:

```

public boolean constains(String string,String subStr) {

if(string == null || subStr == null ){

return false;

}

if(string.equals(subStr)) {

return true;

}

}

```

### 6.最小化嵌套

嵌套很深的代码很难理解,如下代码:

```

if(userResult == SUCCESS) {

if(permissonResult != SUCCESS) {

reply.write("permissonResult error");

reply.done();

return;

}

reply.write("");

} else {

reply.write(userResult);

}

reply.done();

```

最初代码是简单的:

```

if(userResult == SUCCESS) {

reply.write("");

} else {

reply.write(userResult);

}

reply.done();

```

但是后来又添加个一个新的逻辑,代码变成了下面这样:

```

if(userResult == SUCCESS) {

if(permissonResult != SUCCESS) {

reply.write("permissonResult error");

reply.done();

return;

}

reply.write("");

} else {

reply.write(userResult);

}

reply.done();

```

**关键思想:当你对代码修改时,从全新的角度来审视,从整体上来看修改后的影响。**

可以通过提早返回来减少嵌套:

```

if(userResult != SUCCESS) {

reply.write(userResult);

reply.done();

return;

}

if(permissonResult != SUCCESS) {

reply.write("permissonResult error");

reply.done();

return;

}

reply.write("");

reply.done();

```

如何减少循环内的嵌套,在循环中可以使用continue来进实现类似提前返回的效果

```

for(int i = 0; i < results.size(); i ++){

if(results[i] == null) continue;

count++;

if(results[i].getName().equals("")) continue;

print(results[i].getName());

}

```

###总结

- 写一个比较的时候,把改变的值写在左边并且把更稳定的值写在右侧。

- 重新排列if/else语句。通常来讲,先处理正确的、简单的、有趣的情况。

- 避免使用三目运算符、do/while循环。

- 减少代码的嵌套。尽量写的更加线性。

上一篇 下一篇

猜你喜欢

热点阅读