减少代码嵌套
2017-04-06 17:54
169 查看
过多的代码嵌套会影响代码的风格,有时让人感觉不舒服;每一个嵌套的块你都得关注它是和哪个条件句关联的
最好的避免代码嵌套的方法就是尽早返回结果。缓存对这来说是一个很好的例子。与其测试缓存是否失败然后在条件句中再从数据库获取信息,不如判断缓存是否成功然后尽早的返回结果。代码如下:
def get_cached_user(user_id):
user = cache.get_user_by_id(user_id)
if not user:
user = db.get_user_by_id(user_id)
cache.set_user_for_id(user_id,user)
return user
优化后:
def get_cached_user(user_id):
user = cache.get_user_by_id(user_id)
if user:
return user
user = db.get_user_by_id(user_id)
cache.set_user_for_id(user_id,user)
return user
那我们还能使用哪些别的技巧来避免代码嵌套呢?这更多的取决于具体情况。你写一大堆回调函数的时候是不是也容易嵌套?如果是,你通常可以重构你的代码,多用命名函数而不是匿名函数。
最好的避免代码嵌套的方法就是尽早返回结果。缓存对这来说是一个很好的例子。与其测试缓存是否失败然后在条件句中再从数据库获取信息,不如判断缓存是否成功然后尽早的返回结果。代码如下:
def get_cached_user(user_id):
user = cache.get_user_by_id(user_id)
if not user:
user = db.get_user_by_id(user_id)
cache.set_user_for_id(user_id,user)
return user
优化后:
def get_cached_user(user_id):
user = cache.get_user_by_id(user_id)
if user:
return user
user = db.get_user_by_id(user_id)
cache.set_user_for_id(user_id,user)
return user
那我们还能使用哪些别的技巧来避免代码嵌套呢?这更多的取决于具体情况。你写一大堆回调函数的时候是不是也容易嵌套?如果是,你通常可以重构你的代码,多用命名函数而不是匿名函数。
相关文章推荐
- 代码健康: 减少嵌套, 降低复杂性
- 减少 if else 嵌套,提高代码的可读性
- 减少if语句的嵌套层次,提高代码的可读性
- [Code Health]减少嵌套,降低代码复杂度
- 减少代码嵌套的方法
- 用Object.watch减少代码复杂程度
- 用 XDoclet 减少代码膨胀
- J2EE开发中减少编写代码工作量的几种方法
- J2EE开发中减少编写代码工作量的几种方法
- J2EE开发中减少编写代码工作量的几种方法
- 如何用CodeSmith减少代码重复编写
- J2EE开发中减少编写代码工作量的几种方法
- repeater的手写代码绑定,实现分页和嵌套
- 常用网页中嵌套播放器的代码实例
- 构造函数是怎样初始化字段的--减少所生成代码的大小
- 如何减少基于DataSet框架的代码输入量(二)
- PHP树的代码,可以嵌套任意层
- jquery使用attr访问自定义属性,减少javascript脚本中代码和数据的耦合
- 如何减少基于DataSet框架的代码输入量(三)
- 通过 ASP.NET 2.0 的数据增强功能来提高负载和减少代码 --作者:Dino Esposito