编程语言
首页 > 编程语言> > Java入门者:如何写出规范美观的Java代码

Java入门者:如何写出规范美观的Java代码

作者:互联网

前言

在帮助各位同学远程解决代码问题的时候,发现很多同学的代码都有一个共同问题:代码书写格式不规范。虽然代码书写规范对程序性能及运行并不影响,但影响着别人对你编程习惯或能力的第一印象,同时也会给阅读者带来不一样的的观感。

我刚接触编程的时候,代码开发的格式也是随心所欲,这里加一个空格,那里加一个空格。后来在朋友的提醒下,就开始按照<阿里巴巴Java开发手册>来严格要求自己的。工作中也逐渐发现,你更乐意去阅读按照别人规范格式编写的代码。这里先写一个demo进行对比。

入门时写的代码:

  int[] a={1,2,3,4,5};
  int sum=0;
  for(int i=0;i<a.length;i++){
      sum+=a[i];
  }

现在写的代码:

  int[] a = {1, 2, 3, 4, 5};
  int sum = 0;
  for (int i = 0; i < a.length; i++) {
      sum += a[i];
  }

可能根据上面寥寥几行的代码,你可能觉得两种代码格式并无不同。但是在项目中,往往一个Java源文件里面的代码就有成百上千行。如果用第一种写法,代码看起来就会很紧凑,读起来特别累,所以在实际工作中,基本上都是使用第二种写法。

接下来就盘点一下最基本的代码书写格式规范。

代码格式

空格

1.if/for/while/switch/do等保留字与括号之间都必须加空格

2.任何赋值运算符=、逻辑运算符&&、加减乘除符号、三目运算符的左右两边都要加空格

3.else和前后的大括号都加空格

4.括号(和右边相邻字符之间没有空格; )和左边相邻字符之间也不出现空格;而左大括号{前需要加空格

5.注释的双斜线与注释内容之间有且仅有一个空格

6.方法参数在定义和传入时,多个参数逗号后边必须加空格

以上综合样例:

// abc三个参数逗号后面加空格,方法)和{之间有空格
public static void test(int a, int b, int c) {
    c = 0;
    if (true) {
        a = b + c;
    } else {
        a = a == 1 ? a : 1;
    }
}

7.采用4个空格缩进,禁止使用tab字符

如果使用 tab 缩进,必须设置 1 个 tab 为 4 个空格。IDEA 设置 tab 为 4 个空格时,请勿勾选 Use tab character

8.在进行类型强制转换时,右括号与强制转换值之间不需要任何空格隔开

 long first = 1000000000000L; 
 int second = (int)first + 2;

换行

1.单行字符数限制不超过 120 个,超出需要换行

2.如果是大括号内为空,则简洁地写成{}即可,大括号中间无需换行和空格

口诀:左大括号前不换行,左大括号后换行;右大括号前换行,右大括号后还有 else 等代码则不换行;表示终止的右大括号后必须换行

3.不同逻辑、不同语义、不同业务的代码之间插入一个空行分隔开来以提升可读性

命名规范

1.代码中的命名均不能以下划线或美元符号开始和结束

2.方法名、参数名、成员变量、局部变量都统一使用lowerCamelCase风格。

3.任何命名禁止使用中英文混合或者中文拼音

4.在long或者Long赋值时,数值后使用大写的L,不能是小写的

错误示范:

// 1 应该是name,中间可以用_和$
int _name = 1;
int name$ = 2;
// 2 正确的应该是countSumAll
int countsumall = 0;
// 3 不应该用拼音,应该用price来表示价格
int jiage = 10;

建议

上面就是最常见的一些代码书写规范。包括Java其他方面例如集合操作等规范,这些皆在<阿里Java开发手册>中有迹可循。所以建议刚入门的小伙伴们,在刚开始学习Java编程的时候,就依照手册里的规范来要求自己,养成良好的编码习惯。

阿里巴巴Java开发手册泰山版

后台回复关键字 Java开发手册 即可获取<阿里Java开发手册泰山版>PDF。

最后,希望你我共勉。


写的都是日常工作中的亲身实践,处于自己的角度从0写到1,保证能够真正让大家看懂。

文章会在公众号 [入门到放弃之路] 首发,期待你的关注。

公众号

标签:Java,int,美观,空格,换行,入门者,代码,大括号
来源: https://blog.csdn.net/CatchLight/article/details/112916502