2. 源文件规范
2.1 文件名
源文件以最顶层的类名来命名,大小写敏感,文件扩展名为.java
2.2 文件编码 UTF-8
源文件要求编码格式为UTF-8
2.3 源文件结构
一个源文件包含(按顺序地):
许可和版权信息(如有需要)
package语句
import语句
一个顶级类(只有一个)
以上每个部分之间用一个空行隔开
2.4 文件长度
按照sun的规范,代码行数尽量不要超过2000行
2.5 import语句
禁止使用通配的方式import,列如:import java.utils.*
3. 排版格式
3.1 大括号
3.1.1 使用大括号
大括号与if, else, for, do, while语句一起使用,即使只有一条语句(或是空),也应该把大括号写上。
比如:
if(a==b) {
return true;
}
3.1.2 非空块
对于非空块和块状结构,大括号遵循Kernighan和Ritchie风格 (Egyptian brackets):
l 左大括号前不换行
l 左大括号后换行
l 右大括号前换行
l 如果右大括号是一个语句、函数体或类的终止,则右大括号后换行; 否则不换行。例如,如果右大括号后面是else或逗号,则不换行。
3.1.3 空块
一个空的块状结构里什么也不包含,大括号可以简洁地写成{},不需要换行。例外:如果它是一个多块语句的一部分(if/else 或 try/catch/finally) ,即使大括号内没内容,右大括号也要换行。
比如:
void doNothing() {}
3.2 缩进(indentation)
每当开始一个新的块,缩进增加4个tab,当块结束时,缩进返回先前的缩进级别。缩进级别适用于代码和注释。
3.3 行宽(line width)
行宽采用120字符的限制
3.4 自动换行
一般情况下,一行长代码为了避免超出列限制(120个字符)而被分为多行,我们称之为自动换行(line-wrapping)。
3.4.1 什么时候自动换行
自动换行的基本准则是:更倾向于在更高的语法级别处断开。
l 如果在非赋值运算符处断开,那么在该符号前断开(比如+,它将位于下一行)。这条规则也适用于以下“类运算符”符号:点分隔符(.),类型界限中的&(<T extends Foo & Bar>),catch块中的管道符号(catch(FooException | BarException e)
l 如果在赋值运算符处断开,通常的做法是在该符号后断开(比如=,它与前面的内容留在同一行)。这条规则也适用于foreach语句中的分号。
l 方法名或构造函数名与左括号留在同一行。
l 逗号(,)与其前面的内容留在同一行。
3.5 空行
空行将逻辑相关的代码段分隔开,以提高可读性。
下列情况应该总是使用两个空行:
l 一个源文件的两个片段(section)之间
l 类声明和接口声明之间
下列情况应该总是使用一个空行:
l 两个方法之间
l 方法内的局部变量和方法的第一条语句之间
l 块注释或单行注释参加注释规范
l 一个方法内的两个逻辑段之间,用以提高可读性
3.6 使用Eclipse的formatter
2. 导入eclipse: Window → Preferences → Java → Code Style → Formatter → Import →选择文件
3. 格式化
a) 手动格式化: 右键Java文件选择Source→Format或者通过快捷键 Ctrl + Shift + F来对文件进行格式化
b) 自动格式化: Window→ Preferences -→ Java -→ Editor -→ Save Actions,先勾选"Perform the selected actions on save",再勾选"Formatsource code"
3.7 空格
" ="、"+"、"<"、">"、"!="等符号左右两边都必须有空格,如:String str = "自动化测试";
4. 命名规范(不能用拼音)
4.1 工程名
按照所属项目名称命名以UpperCamelCase风格编写。
4.2 包名
包名全部小写,包名的前缀总是一个顶级域名,通常是com, edu, gov, mil, net, org, 或1981年ISO 3166标准所指定的标识国家的英文双字符代码。包名的后续部分根据不同机构各自内部的命名规范而不尽相同。
以创盟为例:com.xunions.mng——创盟后台管理
4.3 类名
类名都以UpperCamelCase风格编写,通常为名词,尽量避免不被广泛使用的缩写.
如:CreateSpace——创建空间
4.4 方法名
方法名都以UpperCamelCase风格编写,通常为动词。
4.5 常量名
全部字母大写,用下划线分隔单词。
普遍认为final定义的变量即为常量,但并不绝对,只有认为永远不会改变的才为常量
比如logger, 我们一般不认为是常量:
static final Logger logger = Logger.getLogger(MyClass.getName());
建议: 因为一些代码检查工具, 比如sonar会检查final的常量名必须为大写,可以考虑logger不加final
4.6 变量名
以lowerCamelCase风格编写
4.7 局部变量和类属性重名
局部变量和类属性重名,虽然是合法的,但是如果没有IDE工具颜色标识,会让人误解。
4.8 长整形数值以大写'L'结尾
对于长整形数值来说,以小写'l'结尾,很容易误看为1,所以应该使用大写'L'。
long userId=23l; // 使用了小写l
long userId=23L; // 使用大小L
4.9 Spring Bean命名
使用类名本身, 并且第一个字母小写
5. 注释规范
良好的注释习惯,是一个优秀的开发人员需要具备的基本素养。
Java的注释分两种,实现注释(implementationcomments)和文档注释(document comments)。
5.1 实现注释(Implementation Comments)
注释模板
/**
* Create by 姓名 on 2016/9/5 11:07
* Function:个人中心页面
* Desc:
*/
备注
1.姓名、时间、功能一定要有,
2.当功能复杂是时候,就需要在描述中给出一些解释,否则可以省略
5.2 文档注释(Documentation Comments)
文档注释描述Java的类、接口、构造器,方法,以及字段(field)。每个文档注释都会被置于注释定界符/**...*/之中,一个注释对应一个类、接口或成员。该注释应位于声明之前:
注释模板
/**
* 说明方法的作用
* @param context 上下文
* @param attrs 属性
* @param defStyleAttr 默认属性
* @return 说明返回值作用
*/
备注
1.构造方法,公有方法,私有方法按照此注释模板注释,
2.如果简单的方法可以使用双斜杠注释,但方法一定可以"见名知意"
3.重载的方法每个都需要按照此方法注释
4.复写的方法如果和父类实现不一样的功能,需要在注释中说明
- appium+python 【Mac】UI自动化测试封装框架介绍 <七>---脚本编写规范
脚本的使用,注释非常关键,无论自己的后期查看还是别人使用,都可以通过注释很明确的知道代码所表达的意思,明确的知道如何调用方法等等.每个团队均有不同的商定形式来写脚本,因此没有明确的要求和规范来约束.如 ...
- Postman接口测试脚本编写规范
Postman接口测试脚本编写规范 1.前言 2.名词解释 3.接口测试脚本规范 3.1接口测试脚本编写的规范 3.2 Postman使用规范 4.单个接口测试 5.整个流程的开发过程 1.前言 本规 ...
- shell脚本编写规范和相关变量类型
shell编程规范与变量 一.shell脚本概述 ① 什么是shell? Linux中有哪些shell? ② shell的作用 ③ 用户的登录shell ④ shell脚本 ...
- robot脚本编写规范
一个robot脚本主要有四部分组成: ***settings*** 设置 ***keywords*** 关键词 ***variables*** 变量 ***test cases*** 测试用例 一般, ...
- robotframework 脚本编写规范
测试集.脚本 测试脚本的名字不要超过20个字符,文件类型应该为txt 名字必需易读且有意义(看名知意) 记住测试集的名字是自动根据文件.目录的名字创建的.后缀名会被截去,下划线会转换为空格,如果名 ...
- Selenium脚本编写环境的搭建/XPath
编写环境主要分为三个部分: JUnit : java单元测试框架: Firebug: firefox 附加组件,Firebug是firefox下的一个扩展,能够调试所有网站语言,如Html,Css等, ...
- 【Shell Basic】Shell脚本编写规范
shell脚本需要有较高的实用性.可维护.可阅读.方便他人阅读,因而需要建立一定的规范来操作 dream361@master:~$ cat test2.sh #!/bin/bash 所使用的bash程 ...
- Shell脚本编写规范
shell脚本需要有较高的实用性.可维护.可阅读.方便他人阅读,因而需要建立一定的规范来操作 dream361@master:~$ cat test2.sh #!/bin/bash 所使用的bash程 ...
- Java语言的编写规范
,区别大小写.2,注意编程格式,比如对齐啊 什么的.3,注释一定要写好,有统一的// 或者/* */,这样让程序好看.4,定义变量的时候竟让别人看明白,不要A 啊B 啊什么的 要用英语单词这类的,简而 ...
随机推荐
- python_接口自动化测试_处理参数替换
在进行自动化测试时,通常会存在A接口用例的返回值是B接口用例的入参这样的情况 可进行如下方式处理: step1.处理A用例时,在响应结果中提取出该数据的值,并赋给一变量,比如 exeId = res. ...
- JMeter_事务控制器
性能测试的结果统计时我们一定会关注TPS,TPS代表的是每秒事务数,每个事务对应的是我们的请求.虽然JMeter能够帮我们把每个请求统计成一个事务,但有时候我们希望把多个操作统计成一个事务,JMete ...
- Word2010邮件合并制作成绩单
原文链接: https://www.toutiao.com/i6488941003494392333/ 准备数据源: 选择"邮件"选项卡,"开始邮件合并"功能组 ...
- Python爬虫脚本 ,Uni-APP复选框做出双向绑定 ,Net5工作流建模 。的一点经验
从业C#开发多年,现在也经常用到Python 做网络爬虫 ,用Uni-app做手机前端.攒了一点经验.供其他多语言开发程序员借鉴吧. Python做爬虫和其他的方式做爬虫最大的区别应该在于. Pyth ...
- lvgl移植—Linux fbdev&evdev(基于LVGL v7)
虽然lvgl官方提供了有关linux framebuffer操作的库函数,但是我决定自己试一下能否自己实现这部分操作 实际项目中应优先采用官方库函数,官方实现代码位于文件夹lv_drivers/dis ...
- Python网络编程之网络基础
Python网络编程之网络基础 目录 Python网络编程之网络基础 1. 计算机网络发展 1.1. OSI七层模型 1.2. 七层模型传输数据过程 2. TCP/IP协议栈 2.1 TCP/IP和O ...
- JAVA之垃圾收集器
概述 垃 圾收集 Garbage Collection 通常被称为"GC",它诞生于1960年 MIT 的 Lisp 语言,经过半个多世纪,目前已经十分成熟了. jvm 中,程序计 ...
- MATLAB中拟合算法刚入门
%%%1.拟合问题:(做预测,主要使用的范围是样本比较小,拟合效果会好,样本比较多,拟合的效果就不是很好) 1.应用预测的场景:已经知道10年的样本,预测第11年以内的数据 2.用拟合的到关系式:样本 ...
- 《剑指offer》面试题56 - II. 数组中数字出现的次数 II
问题描述 在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次.请找出那个只出现一次的数字. 示例 1: 输入:nums = [3,4,3,3] 输出:4 示例 2: 输入:nums ...
- 极简promise雏形
function Promise(fn) { var value = null, callbacks = []; //callbacks为数组,因为可能同时有很多个回调 this.then = fun ...