亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

一道代碼評審題

標簽:
Java 面試

今天在qq的java群里面,有同学贴了一道代码评审题 图片描述

这块看上去写得还可以的代码,我说说个人的看法

问题1:最大的问题就是方法名,这个函数实际上是有数据操作的,不应该叫getXXX,给人一种人畜无害的感觉。调用者不会想到里面把数据改了。

问题2: 【可能】存在的空指针异常。order可能为空,是否必须要加空判断呢?我的意见是不一定。具体原因见此贴:我的编码习惯 - 异常处理

问题3: 魔法数字0和1

问题4:没有日志,我个人建议,数据操作还是应该带上日志,方便跟踪。如果真的只是查询数据,不加日志没有关系,参见此贴:我的编程习惯 - 日志建议

问题5: 这里的字符串拼接不需要自己使用 StringBuffer。这个严格来讲不算是问题,只是很多人不知道这个知识点。当然你这样写不是问题,如果你本来没有使用StringBuffer拼接字符,评审的是说要改成StringBuffer来拼接字符串,那就不应该了。这应该都是很老的编程规范了!

简单说明一下,jdk实际上已经给大家做了这一步了,看代码

/**
 * 使用 javap -c StringDemo.class 反编译看字节码
 * @author 晓风轻
 *
 */
public class StringDemo {

  private String name;

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

  public static void main(String[] args) {
    StringDemo demo = new StringDemo();

    demo.setName("晓风轻");

    String s = "我的名字是[" + demo.getName() + "].";
    System.out.println(s);
  }

}

使用 javap -c StringDemo.class 反编译看字节码:

javap

可以看出,字节码里面已经自动使用StringBuilder拼接字符串了。

點擊查看更多內容
5人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
全棧工程師
手記
粉絲
1.1萬
獲贊與收藏
1074

關注作者,訂閱最新文章

閱讀免費教程

感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消