优雅编程之项目开发中的22点编码小建议(三十七)

开心一笑

【建议大家尝试早睡觉,多运动,不吃宵夜,不抽烟,不喝酒,早睡早起,养成一个良好的生活习惯,久而久之,你就......一个朋友都没有了,好可怜的样子啊!】

提出问题

项目开发过程中应该注意的几点编码规范???

解决问题

唯美图片

本来不想写这篇文章的。之前在《优雅编程系列》的文章中,都有提过了。但是主管说要收集一些编码规范的建议,就针对公司情况,随便写几点,越写越生气,越生气就越想骂人,越想吐槽。下面分享几点,get起来,以后不要再犯了......

1.接口里面的方法默认都是public

不用再加public修饰

2.字符串变量和字符串常量equals的时候将字符串常量写在前面,可以避免空指针。

如:

if("123".equals(str)){
}
3.不要创建一些不使用的对象,不要导入一些不使用的类

类中import 没用的类要及时删除。

4.for循环建议写法
for (int i = 0, int length = list.size(); i < length; i++)
5.循环内不要不断创建对象引用

如:

for (int i = 1; i <= count; i++){
    Object obj = new Object();
}

改为:

Object obj = null;
for(int i = 0; i <= count; i++){
    obj = new Object(); 
}
6.尽量避免随意使用静态变量

如:

public class A{ 
    private static B b = new B();
}

此时静态变量b的生命周期与A类相同,如果A类不被卸载,
那么引用B指向的B对象会常驻内存,直到程序终止

7.方法的返回值不要为空

如:return null;

1.返回List:

private List<PcsTaskDTO> sortDecisionAndBackTask(List<PcsTaskDTO> pcsTaskDTOList) throws Exception{
        if(CollectionUtils.isEmpty(pcsTaskDTOList)) return null;
}

解决方法:

private List<PcsTaskDTO> sortDecisionAndBackTask(List<PcsTaskDTO> pcsTaskDTOList) throws Exception{
        if(CollectionUtils.isEmpty(pcsTaskDTOList)) return Collections.EMPTY_LIST;
}

2.返回Set:

Collections.EMPTY_SET

3.返回Map:

Collections.EMPTY_MAP
8.不要再for循环中查询数据库

小心第三方测试公司弄死你!

9.代码层级不要太深,最多3层

如:

/**
 * 只做一件事
 */
public void onlyDoOneThing(){
    String ay = "";
    Boolean flag = true;
    /** 第一层级 不错 **/
    if(flag){

        /** 第二层级 还能接受 **/
        if(flag){

            /** 第三层级 没法接受了 **/
            if(flag){

            }
        }
    }
}
10.每个方法的代码不要太长

如果一个方法的代码超过一屏幕,建议拆分为多个

如:
if(){
..业务代码1
}else{
..业务代码2
}

for(int i=0;i<100;i++){
    ..业务代码3
}

对于if,和for中的代码,如果是处理业务代码,一般可以抽出单独的一个代码,改成

if(){
    method1();
}else{
    method2();
}

for(int i=0;i<100;i++){
    method3();
}   

method1(){
    //业务代码1
}


method2(){
    //业务代码2
}


method3(){
    //业务代码3
}
11.函数参数:应该少于2个

如果函数超过2元:应该将其中的某些参数封装成类;

例:

/**
 * 只做一件事
 * @param arg1  参数1
 */
public void onlyDoOneThing(String arg1){

    System.out.println("一个参数,不错!!!");
}

/**
 * 只做一件事
 * @param arg1  参数1
 * @param arg2  参数2
 */
public void onlyDoOneThing(String arg1,String arg2){

    System.out.println("两个参数,能接受和理解!!!");
}

/**
 * 只做一件事
 * @param arg1  参数1
 * @param arg2  参数2
 * @param arg3  参数3
 * @param arg4  参数4             
 */
public void onlyDoOneThing(String arg1,String arg2,String arg3,String arg4){

    System.out.println("3个或3个以上的参数,没法接受!!!");
}
12.删掉被注释掉的代码

除非那段代码,删掉人会死掉。

13.避免括号后面的注释

错误注释比不注释跟可怕,最好做到代码既注释。

如:下面提供一个例子,方便理解:

package com.hwy.test;

/**
 * 代码整洁之道
 * Created by Ay on 2016/7/11.
 */
public class CodeCleanTest {

    public static void main(String[] args) {

        /** 这段代码是不需要注释的,看方法名称就可以清楚知道意图了 **/
        engagements();
        boolean isMerryMe =  canMerryMe();
        if(isMerryMe){//避免括号后面的注释,例如这

            getMarried();
            /** 删掉被注释掉的代码; **/
            //String ring = "";
        }

        /** TODO注释,提示尚未完成的工作 **/
        //TODO 结婚生子

        /** 悄悄话内容,这里涉及到一些业务上的事,所以需要注释下 **/
        String whisperContent =  getwhisperContent();
    }


    /**
     * 获得悄悄话内容
     * @return
     */
    public static String getwhisperContent(){
        return "XXX OOO";
    }

    public static void engagements(){
        System.out.println("约会");
    }

    public static boolean canMerryMe(){
        boolean isLoveMe = true;
        if(isLoveMe)return true;
        return false;
    }

    public static void getMarried(){
        System.out.println("结婚");
    }

}
14.不要使用单个字母来做变量名

时间一长,自己都不清楚自己当初的命名是什么意思

15.不要使用有误导性的字母作为变量名

比如小写字母l和大写字母O,因为他们和数字的1和0很像(老话题了)

16.类名和对象名一般都是名词和名词短语,而不应当使用动词
17.方法名一般是动词和动词短语;get,set,is前缀

如:

public void getUsers();
public void getData();
public void isCompleted();
18.对于方法名

应该保持一致,比如对于绑定数据的方法,不要有的地方用BindData,而另一些地方使用DataBind ;

19.避免误导:userList的类型最好就是List

例:

//错误
String userList = "";
//正确
List<String> userLit = new ArrayList<>(); 
20.使用可搜索的名称:避免使用单字母变量和数字常量

错误:

int s = 0;
for(int i=0;i<100;i++){
    s = s + i;
}

正确:

//起码sum在搜索时比较方便
int sum = 0;
for(int i=0;i<100;i++){
    sum = sum + i;
}    
21.单行代码长度

以不拖动滚动条为准则,代码行长度80个字符可以接受,最多120个字符,再多,你想逆天啊!

22.去掉System.out.println

代码部署到生产环境前,去掉全部System.out.println

读书感悟

来自 弗兰西斯·培根《培根论人生》

  • 如果问在人生中最重要的才能是什么?那么回答则是:第一,无所畏惧;第二,无所畏惧;第三,还是无所畏惧。
  • 人生如同道路。最近的捷径通常是最坏的路。
  • 在世之时与人为恶,到头来却是于己不幸。
  • 没有真挚朋友的人,是真正孤独的人。
  • 奇迹多是在厄运中出现的。
  • 凡过于把幸运之事归功于自己的聪明和智慧的人多半结局是不幸的。
  • 有些书可供一赏,有些书可以吞下,有不多的几部书则应当咀嚼消化;有的书只要读读其中一部分就够了,有些书可以全读,但是不必细心地读,还有不多的几部书则应当全读、勤读,而且用心地读。

经典故事

【有个小弟在脚踏车店当学徒。有人送来一部坏了的脚踏车,小弟除了将车修好,还把车擦拭得漂亮如新,其他学徒笑他多此一举。车主将脚踏车领回去的第二天,小弟被挖到他的公司上班。启发:原来出人头地很简单,勤快点就行】

参考文章

【1】写出优雅性能的JAVA程序必须遵守的35个原则
【2】Effective java 第二版本
【3】clean code(代码整洁之道)
【4】Thinking in Java(Java编程思想)

唯美图片

其他

如果有带给你一丝丝小快乐,就让快乐继续传递下去,欢迎点赞、顶、欢迎留下宝贵的意见、多谢支持!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • #下一世纪##1840-1949世界史# 序 1840年的枪声打开了中国的大门 我们的所有人的生命倾没在战火里 我...
    Ussagi阅读 1,201评论 0 1
  • 我看见了,一汪碧水,就躺在群山的怀抱。我站在远远的山腰就看见了它。 我跌撞撞向它奔去,山路太滑,摔倒了,爬起来,手...
    阳光下的稻草人0阅读 313评论 0 1
  • 我想不明白为何要写这文章,我知道你不会看到,曾经,我们是什么关系呢?发小儿,朋友,还是前任?知道我们的人都说...
    飙尘阅读 215评论 0 0