阿里巴巴对Java编程【代码格式】的规约
转载自 阿里巴巴对Java编程【代码格式】的规约
代码格式
1. 【强制】大括号的使用约定。如果是大括号内为空,则简洁地写成{}即可,不需要换行 ; 如果是非空代码块则:
1 ) 左大括号前不换行。
2 ) 左大括号后换行。
3 ) 右大括号前换行。
4 ) 右大括号后还有 else 等代码则不换行 ; 表示终止的右大括号后必须换行。
2. 【强制】 左小括号和字符之间不出现空格 ; 同样,右小括号和字符之间也不出现空格。详见第 5 条下方正例提示。
反例: if (空格 a == b 空格)
3. 【强制】 if / for / while / switch / do 等保留字与括号之间都必须加空格。
4. 【强制】任何二目、三目运算符的左右两边都需要加一个空格。
说明:运算符包括赋值运算符=、逻辑运算符&&、加减乘除符号等。
5. 【强制】采用 4 个空格缩进,禁止使用 tab 字符。
说明:如果使用 tab 缩进,必须设置 1 个 tab 为 4 个空格。IDEA 设置 tab 为 4 个空格时,
请勿勾选 Use tab character ;而在 eclipse 中,必须勾选 insert spaces for tabs 。
正例: ( 涉及 1-5 点 )
public static void main(String[] args) {// 缩进 4 个空格 String say = "hello"; // 运算符的左右必须有一个空格 int flag = 0; // 关键词 if 与括号之间必须有一个空格,括号内的 f 与左括号,0 与右括号不需要空格 if (flag == 0) {System.out.println(say); } // 左大括号前加空格且不换行;左大括号后换行 if (flag == 1) {System.out.println("world"); // 右大括号前换行,右大括号后有 else,不用换行 } else {System.out.println("ok"); // 在右大括号后直接结束,则必须换行 } }
6. 【强制】注释的双斜线与注释内容之间有且仅有一个空格。
正例: // 注释内容,注意在 // 和注释内容之间有一个空格。
7. 【强制】单行字符数限制不超过 120 个,超出需要换行,换行时遵循如下原则:
1) 第二行相对第一行缩进 4 个空格,从第三行开始,不再继续缩进,参考示例。
2 ) 运算符与下文一起换行。
3 ) 方法调用的点符号与下文一起换行。
4 ) 方法调用时,多个参数,需要换行时,在逗号后进行。
5 ) 在括号前不要换行,见反例。
正例:
StringBuffer sb = new StringBuffer(); // 超过 120 个字符的情况下,换行缩进 4 个空格,点号和方法名称一起换行 sb.append("zi").append("xin")... .append("huang")... .append("huang")... .append("huang");
反例:
StringBuffer sb = new StringBuffer();
// 超过 120 个字符的情况下,不要在括号前换行 sb.append("zi").append("xin")...append ("huang"); // 参数很多的方法调用可能超过 120 个字符,不要在逗号前换行 method(args1, args2, args3, ... , argsX);
- 8. 【强制】方法参数在定义和传入时,多个参数逗号后边必须加空格。
正例:下例中实参的" a ",后边必须要有一个空格。
method("a", "b", "c");
9. 【强制】 IDE 的 text file encoding 设置为 UTF -8 ; IDE 中文件的换行符使用 Unix 格式,不要使用 Windows 格式。
10. 【推荐】没有必要增加若干空格来使某一行的字符与上一行对应位置的字符对齐。
正例:
int a = 3; long b = 4L; float c = 5F; StringBuffer sb = new StringBuffer();
说明:增加 sb 这个变量,如果需要对齐,则给 a 、 b 、 c 都要增加几个空格,在变量比较多的情况下,是一种累赘的事情。
11. 【推荐】方法体内的执行语句组、变量的定义语句组、不同的业务逻辑之间或者不同的语义之间插入一个空行。相同业务逻辑和语义之间不需要插入空行。
说明:没有必要插入多个空行进行隔开。
阿里巴巴对Java编程【代码格式】的规约相关推荐
- 阿里巴巴对Java编程【注释规约】的规约
转载自 阿里巴巴对Java编程[注释规约]的规约 注释规约 1. [强制]类.类属性.类方法的注释必须使用 Javadoc 规范,使用/**内容*/格式,不得使用// xxx 方式. 说明:在 ID ...
- 阿里巴巴对Java编程【控制语句】的规约
转载自 阿里巴巴对Java编程[控制语句]的规约 控制语句 1. [强制]在一个 switch 块内,每个 case 要么通过 break / return 等来终止,要么注释说明程序将继续执行到哪一 ...
- 阿里巴巴对Java编程【并发处理】的规约
转载自 阿里巴巴对Java编程[并发处理]的规约 并发处理 1. [强制]获取单例对象需要保证线程安全,其中的方法也要保证线程安全. 说明:资源驱动类.工具类.单例工厂类都需要注意. 2. [强制]创 ...
- 阿里巴巴对Java编程【集合处理】的规约
转载自 阿里巴巴对Java编程[集合处理]的规约 集合处理 1. [强制]关于 hashCode 和 equals 的处理,遵循如下规则: 1) 只要重写 equals ,就必须重写 hashCode ...
- 阿里巴巴对Java编程【常量定义】的规约
转载自 阿里巴巴对Java编程[常量定义]的规约 常量定义 1. [强制]不允许任何魔法值 ( 即未经定义的常量 ) 直接出现在代码中. 反例: String key = " Id # t ...
- 阿里巴巴对Java编程【命名风格】的规约
转载自 阿里巴巴对Java编程[命名风格]的规约 命名风格 1. [强制]代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束. 反例: _name / __name / $Obje ...
- 阿里巴巴对Java编程【应用结构】的规约
转载自 阿里巴巴对Java编程[应用结构]的规约 应用分层 1. [推荐]图中默认上层依赖于下层,箭头关系表示可直接依赖,如:开放接口层可以依赖于Web 层,也可以直接依赖于 Service 层,依此 ...
- 阿里巴巴对Java编程【Mysql】的规约
转载自 阿里巴巴对Java编程[Mysql]的规约 建表规约 1. [强制]表达是与否概念的字段,必须使用 is _ xxx 的方式命名,数据类型是 unsigned tinyint( 1 表示是,0 ...
- 阿里巴巴对Java编程【安全规约】的规约
转载自 阿里巴巴对Java编程[安全规约]的规约 安全规约 1. [强制]隶属于用户个人的页面或者功能必须进行权限控制校验. 说明:防止没有做水平权限校验就可随意访问.修改.删除别人的数据,比如查看他 ...
最新文章
- 华为鸿蒙运行视频,某游戏在华为鸿蒙运行,被识别成使用安卓模拟器
- 女朋友求爱c语言程序,[转载]一个程序员写的求爱程序
- 人体姿态估计研究文集
- java中Arrays的用法
- 开发软件真是一件有意思的事情
- 0420第一次团队合作
- python学习笔记(七)
- 《软件项目管理(第二版)》第 4 章——项目估算 重点部分总结
- 【转载】移植FFMpeg到VC环境心得
- python编程基础之二十九
- The Python Debugger Command
- 利用CSS3的transform做的动态时钟
- zookeeper分布式安装与配置
- angular框架的SmartAdmin模板 如何请求后台数据
- oracle和timesten整合,Timesten与Oracle SQL执行时间对比
- VScode提交Git代码总是要输入账号和密码?
- The Little Schemer Fourth Edition,笔记01
- part3_模块五作业
- python爬取电影信息并插入至MySQL数据库
- android话费查询接口,Android 小应用--一键查话费移动版(附源码)
热门文章
- 16位无符号比较器设计
- C++ class实现十字链表存储的图(完整代码)
- php post nginx 400,Nginx静态文件响应POST请求 提示405错误的解决方法
- cmd小游戏_使用pygame制作Flappy bird小游戏
- python结束线程_2018-01-02 如何优雅地终止python线程
- CF773F Test Data Generation(倍增FFT/动态规划)
- Codeforces Round #703 (Div. 2) E. Paired Payment 最短路 + 思维
- 【UOJ574】多线程计算【二元二项式反演】【定积分】【矩阵】【NTT 卷积】
- CF917B MADMAX
- [TJOI2008]彩灯