百科问答小站 logo
百科问答小站 font logo



项目组里的代码审查员要我把代码写的很啰嗦,怎么办? 第1页

  

user avatar   yao-dong-27 网友的相关建议: 
      

我有时也会写成这样

       boolean flag = getMboValue().isNull(); if (flag) {     this.getMboValue("vendor").setReadOnly(false); } else {     this.getMboValue("vendor").setReadOnly(true); }     

原因是这样方便下断点调试,比如 flag是true为正常,false是异常情况需要调试。写成一行断点就不好下了。

我也不反对这种情况直接写成一行,只要命名合理逻辑清晰可读就好

我反对以下这样一行的写法:

       foo.setDisable( ! (bar.isEnable()  && this.getValue().isNull()) );     

肯定、否定、并且、取反来回兜几个圈后我脑子就冒烟了,智商欠费。


user avatar   Ivony 网友的相关建议: 
      

首先,很显然的代码审查员的建议写法除了增加代码量之外,在可读性方面并没有太多的提升,甚至因为代码量的提升带来更多的心智负担和出错的概率。

例如因为某个奇怪的失误把代码写成了这样:

       boolean flag = getMboValue().isNull(); if (flag) { this.getMboValue("vendor").setReadOnly(false); } else { this.getMboValue("vendor").setReadOnly(false); }     

所以,原本一个可能出现问题的地方现在变成了四五个。


除此之外,flag的命名不够meaning,而我也倾向于移除这个变量,毕竟这个表达式并不长。但与上面不同的是,我个人会建议完全弃用 ! 运算符,原因是这个运算符实在是太不够明显了。所以我个人建议的写法是:

       this.getMboValue("vendor").setReadOnly( getMboValue().isNotNull() );     

增加一个isNotNull方法来使得语义更为清晰。

或者:

       this.getMboValue("vendor").setReadOnly( getMboValue().hasValue() );     

在无法增加方法的情况下,我也会建议用 == false来代替 ! ,因为在字面上这样会更难以被忽略:

       this.getMboValue("vendor").setReadOnly( getMboValue().isNull() == false );     

比较一下:

       this.getMboValue("vendor").setReadOnly( !getMboValue().isNull() );     

很显然上面的写法在提醒看的人,嘿,哥们儿注意点,我这里是反的。




当然,抛开代码审查员的问题,作为一个一无所知的程序员来重新审视这段代码,我会发现Mbo这个缩写其实会非常的令人费解,而且getMboValue这个方法实在是出现了太多次,另外为代码中一个有this,另一个没有this,让这段逻辑更加离奇。


最后,童鞋你写大括号的习惯我很欣赏,趁着你们的代码审查员还没有让你把所有的大括号都变成半展开之前,赶紧换工作投入大C#的怀抱吧……到时候同样的代码可能只需要写成这样就可以了:

mbo["vendor"].ReadOnly = mbo["vendor"] != null;


user avatar   qin.chao 网友的相关建议: 
      

景甜:抱歉,是我选的他。




  

相关话题

  软件工程本科分方向,.NET和Java选哪个好? 
  为什么很多程序员不用 switch,而是大量的 if...else if ...? 
  windows如何监控文件的修改? 
  行业内对低代码开发是什么看法? 
  程序员写代码不应该是一件很酷的事情吗?为什么在国内被打上无聊和呆板的标签? 
  一个文件分发服务器,要支持多个(几千个)请求下载,文件比较大,用java socket,ftp还是http支持? 
  if(x>y)和if(x-y>0)有没有区别(x,y都是int)? 
  今年刚考上机械研究生,想着混个毕业,自学三年java毕业转行可行吗? 
  编程中如何给变量命名?有哪些规范的做法值得学习借鉴? 
  为何部分程序员从不使用 break 或 continue 语句? 

前一个讨论
维基百科比百度百科差在哪里?
下一个讨论
女性健身的常见误区和谣言有哪些?





© 2025-06-29 - tinynew.org. All Rights Reserved.
© 2025-06-29 - tinynew.org. 保留所有权利