Discuz教程网

好的代码里只要一个 return 语句

[复制链接]
authicon dly 发表于 2011-5-18 11:04:38 | 显示全部楼层 |阅读模式
别再这样写了:

  1. public boolean foo() {
  2. if (true) {
  3. return true;
  4. } else {
  5. return false;
  6. }
  7. }
复制代码

每次当我深入某个开源项目,看到大概是某个专家写的、并被有经验的专业人士审查过的这样的代码,我都会惊讶不已,竟然没有人去阻止这个开发者在这个方法里胡乱的放置返回语句。
请告诉我,把代码写成下面的样子很难吗?

  1. public boolean foo() {
  2. boolean flag = true;
  3. if (true) {
  4. flag=true;
  5. }
  6. else {
  7. flag=false;
  8. }
  9. return flag;
  10. }
复制代码

这是Java基本常识。实际上,这不仅是Java基本常识,这是小学水平的Java知识。如果你的方法返回一个值,你应该在方法的开始处把它声明做一个变量。然后再去做一些赋予这个变量正确意义的操作。然后,在你的最后一行,把这个变量返回给调用程序。这样做不仅仅是为写出好的代码,这是一种有教养的表现。
你是否曾试图修改过一些在方法里到处都是返回语句的程序代码?无从下手。事实上,去维护这样的代码,你第一要做的是重新组织它的结构,让它里面不再有一大堆的返回语句。这样才能把事情做好。没有任何一个方法是不可以写成只在末尾处有一个的、单一的、易于找到的返回语句的形式的。
的确,烂程序员总有一万个理由来说明他们为什么编写出这样糟糕的程序代码。“我只是为了避免在返回时一堆的多余的条件判断语句。”那好,首先,我告诉你, 计算机中执行一些条件判断语句时是该死的快,你用短路一个方法来节省CPU的一两个指令操作不是显的太荒诞了吗。此外,如果这些所谓多余的条件判断语句最终没有派上用场的话,这是否是一个有用的信号来说明你的“多余”的代码可能需要重写,也许可以把它们重构成另外一个方法,让它们显的不多余?
关键要说的是,没有任何理由可以为写糟糕的代码或当懒惰的程序员做托辞,特别是当写出好的代码并不是那么困难的情况下。不要在写出里面有成百上千个返回语句的方法了。Java里的方法只可以返回一个值,相应的,一个方法应该有且只有一个返回语句。





上一篇:25个不错PHP的游戏编程脚本代码分享
下一篇:php文件类型对照表
authicon 皆无 发表于 2011-5-18 19:29:45 | 显示全部楼层
哈哈,支持了
authicon yuki佳 发表于 2011-5-18 23:29:54 | 显示全部楼层
哈哈  收了你
authicon huanglv80 发表于 2011-5-19 04:29:54 | 显示全部楼层
顶你一下,好贴要顶!
authicon 陶衣小可 发表于 2011-5-19 05:29:35 | 显示全部楼层
我回不回呢 考虑再三 还是不回了吧 ^_^
authicon 82xiaochong911 发表于 2011-5-19 11:29:53 | 显示全部楼层
哈哈,支持了
authicon 蓝天blue 发表于 2011-5-19 18:30:53 | 显示全部楼层
看看  好像不错
authicon fhiejkl 发表于 2011-5-19 23:29:36 | 显示全部楼层
谢谢,学习了
authicon 暗夜的烟火 发表于 2011-5-20 00:30:02 | 显示全部楼层
这个还是不错的!
authicon icenna 发表于 2011-5-20 01:29:55 | 显示全部楼层
这个要顶起来啊
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-5-2 04:55

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表