@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
编程规范
命名规约
1.包名,统一使用小写,单数形式,点分隔符之间仅有一个自然语义的英文单词。但是类名有复数含义,可以使用复数单词。
2.接口类,方法和属性不要加任何修饰符,并加上有效的javadoc注释。
3.各层命名规范:
A)Service/DAO层方法名规约
1) 获取单个对象的方法用get做前缀。
2) 获取多个对象的方法用list做前缀。
3) 获取统计值的方法用count做前缀。
4) 插入的方法用save(推荐)或insert做前缀。
5) 删除的方法用remove(推荐)或delete做前缀。
6) 修改的方法用update做前缀。
B)领域模型命名规约
1) 数据对象:xxxDO,x xx即为数据表名。
2) 数据传输对象:xxxDTO,xxx为业务领域相关的名称。
3) 展示对象:xxxVO,xxx一般为网页名称。
4) POJO是DO/DTO/BO/VO的统称,禁止命名成xxxPOJO。
常量定义
1.不允许任何魔法值(即未经定义的常量)直接出现在代码中。
2.long和Long初始赋值时,必须使用大写的L,不能是小写的l。
3.不要使用常量类维护所有的常量,应该按常量功能进行归类,类名以Consts结尾
4.常量的复用层次有五层:跨应用共享常量、应用内共享常量、子工程内共享常量、包内共享常量、类内共享常量 。
1)跨应用共享常量:放置在二方库中,通常是client.jar中的const目录下。
2)应用内共享常量:放置在一方库的modules中的const目录下。
3)子工程内共享常量:即在当前子工程的const目录下。
4)包内共享常量:即在当前包下单独的const目录下。
5)类内共享常量:直接在类内部private static final定义。
格式规约
1.单行字数不超过120个,超出需要换行,换行时,遵循如下原则:
1)换行时相对上一行缩进4个空格。
2)运算符与下文一起换行
3)方法调用的点符号与下文一起换行
4)在多个参数超长,逗号后面进行换行。
5)括号前面不要换行。
2. 方法体内的执行语句组、变量的语义定义组、不同的业务逻辑之间或者不同的语义之间插入一个空行。
OOP规约
1.对外暴露的接口签名,原则上不允许修改方法签名,避免对接口调用方产生影响。接口过时必须加@Deprecated注解,并清晰的说明采用的新接口或者新服务是什么。
2.不能使用过时的类和方法。
3.Object的equals方法容易抛空指针异常,应使用常量或确定有值的对象来调用equals。
说明:推荐使用java.util.Objects.equals(a,b) (JDK7引入的工具类)
4. 关于基本数据类型与包装数据类型的使用标准如下:
1)所有的POJO类属性必须使用包装数据类型。
2)RPC方法的返回值和参数必须使用包装数据类型。
3)所有的局部变量推荐使用基本数据类型。
4)在定义DO\DTO\VO等POJO时,不要设定任何属性默认值。
5.POJO类必须写重写toString()方法 。
6.类内方法的定义顺序:公有方法或者保护方法>私有方法>getter&setter方法。
7.循环体内,字符串的联接方式,使用StringBuilder的append方法进行扩展。
8.final可以提高程序响应效率,声明成final的情况:
1)不需要重新赋值的变量,包括类属性,局部变量。
2)对象参数前加final,表示不允许修改引用的指向。
3)类方法确定不允许被重写。
9.类成员与方法访问控制从严:
1)如果不允许外部直接通过new来访问对象,那么构造方法必须是private。
2)工具类不允许有public和default构造方法。
3)类非static成员变量并且与子类共享,必须是protected。
4)类非static成员变量并且仅在本类使用,必须是private。
5)类static成员变量如果仅在本类使用,必须是private。
6)若是static成员变量,必须考虑是否为final。
7)类成员方法只供类内部调用,必须是private。
8)类成员方法只对继承类公开,那么限制为protected。
集合处理
1.Map/Set的key为自定义对象时,必须重写hashCode和equals。
2.使用集合转数组的方法,必须使用集合的toArray(T[] array),传入的是类型大小完全一样的数组。
3.不要在foreach循环里进行集合元素的remove/add 操作,若要请使用Iterator方式。
4.集合初始化时,尽量指定集合初始值大小。
5. 利用Set元素唯一的特性,可以快速对另一个集合进行去重操作,避免使用List的contains方法进行遍历去重操作。
并发处理
1.线程资源必须通过线程池提供,不允许在应用中自行显示创建线程。
2.高并发时应该去考虑锁的性能损耗,能用无锁数据结构就不要用锁;能锁区块,就不要锁整个方法体;能用对象锁,就不要锁类 。
3.对多个资源、数据库表、对象同时加锁时。需要保持一致的加锁顺序,否则可能会造成死锁。
4.并发修改同一记录时,避免更新丢失,要么在应用层加锁,要么在缓存加锁,要么在数据库层使用乐观锁,使用version作为更新依据,乐观锁的重试次数不得小于3次。
5.线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor去创建。
控制语句
1.在一个switch内必须要有default快,即使什么都没做。
2.在if/else/for/while/do语句中必须使用大括号,即使只有一行代码。
3.推荐尽量少用else,if-else可以用if return来代替,如果使用if-else if-else来表达,不允许超过3层。
4.不要在条件判断中执行复杂的语句,以提高可读性。
5. 方法中需要进行参数校验的场景:
1)调用频次低的方法。
2)执行时间开销很大的方法。
3)需要极高稳定性和可用性的方法。
4)对外提供的开放接口,不管是RPC/API/HTTP接口。
6. 方法中不需要参数校验的场景:
1)极有可能被循环调用的方法,不建议对参数进行校验。
2)底层的方法调用。如dao层不进行校验 。
3)private方法,确认参数不会有问题。
注释规约
1.类、类属性、类方法的注释必须使用javadoc规范,使用/**内容**/格式,不得使用//内容 方式。
2. 所有的抽象方法(包括接口中的方法)必须要用javadoc注释、除了返回值、参数、异常说明外,还应该指出该方法做什么事情,实现什么功能。
3.方法内部进行单行注释使用//,多行注释使用/**/
4.所有的枚举类型字段必须要有注释,说明每个数据项的用途。
5. 代码修改的同时,注释也要跟着修改。
6.注释后的代码要配上说明。
其它
1.在使用正则表达式时,利用好其预编译功能,可以有效加快正则匹配速度。
2.获取当前毫秒数:System.currentTimeMills();如果想获取更精确的纳秒级时间,使用System.nanaoTime()。
3.对于"明确停止使用的代码和配置",要坚决从程序中清理出去。
阿里Java编程规范 学习笔记的更多相关文章
-
阿里java开发规范学习(附P3C IDEA插件 帮助规范的养成)
浅析 阿里巴巴 Java 开发规约 (未完成) 更加优秀的页面展现请到浅析 阿里巴巴 Java 开发规约 contents 为什么要学 编程规约 P3C IDEA 插件 why-use 我们知道,一般 ...
-
[Java编程思想-学习笔记]第3章 操作符
3.1 更简单的打印语句 学习编程语言的通许遇到的第一个程序无非打印"Hello, world"了,然而在Java中要写成 System.out.println("He ...
-
Java编程思想学习笔记_1(Java内存和垃圾回收)
1.Java中对象的存储数据的地方: 共有五个不同的地方可以存储数据. 1)寄存器.最快,因为位于处理器的内部,寄存器按需求分配,不能直接控制. 2)堆栈.位于通用RAM,通过堆栈指针可以从处理器那里 ...
-
Java编程思想 学习笔记1
一.对象导论 1.抽象过程 Alan Kay曾经总结了第一个成功的面向对象语言.同时也是Java所基于的语言之一的Smalltalk的五个基本特性,这些特性表现了纯粹的面向对象程序设计方式 1)万物皆 ...
-
Java编程思想学习笔记——类型信息
前言 运行时类型信息(RTTI:Runtime Type Information)使得我们可以在程序运行时发现和使用类型信息. Java在运行时识别对象和类的信息的方式: (1)一种是RTTI,它假定 ...
-
[Java编程思想-学习笔记]第1章 对象导论
1.1 抽象过程 Java是一门面向对象的语言,它的一个优点在于只针对待解问题抽象,而不用为具体的计算机结构而烦心,这使得Java有完美的移植性,也即Java的口号"Write Once, ...
-
Java编程思想 学习笔记12
十二.通过异常处理错误 Java的基本理念是“结构不佳的代码不能运行”. Java中的异常处理的目的在于通过使用少于目前数量的代码来简化大型.可靠的程序的生成,并且通过这种方式可以使你更加自信:你的 ...
-
Java编程思想 学习笔记11
十一.持有对象 通常,程序总是根据运行时才知道的某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型. Java实用库还提供了一套相当完整的容器类来解决这个问题,其中基本的类 ...
-
Java编程思想 学习笔记10
十.内部类 可以将一个类的定义放在另一个类的定义内部,这就是内部类. 内部类是一种非常有用的特性,因为它允许你把一些逻辑相关的类组织在一起,并控制位于内部的类的可视性.然而必须要了解,内部类和组合是 ...
随机推荐
-
Java IO6:字符流进阶及BufferedWriter、BufferedReader
字符流和字节流的区别 拿一下上一篇文章的例子: public static void main(String[] args) throws Exception { File file = new Fi ...
-
UIButton修改文字大小问题
一.问题描述 通过UIButton对象font属性设置文字大小,却发现该属性在2.0.3.0就已经被废弃,ios不建议使用. 图1-1:点出UIButton对象的font属性提示被废弃 图1-2:UI ...
-
Grandpa's Estate---POJ1228(凸包)
http://poj.org/problem?id=1228 学长说这是稳定凸包,我感觉就是凸包嘛. 所谓稳定就是判断能不能在原有凸包上加点,得到一个更大的凸包,并且这个凸包包含原有凸包上的所有点.知 ...
-
泛函编程(23)-泛函数据类型-Monad
简单来说:Monad就是泛函编程中最概括通用的数据模型(高阶数据类型).它不但涵盖了所有基础类型(primitive types)的泛函行为及操作,而且任何高阶类或者自定义类一旦具备Monad特性就可 ...
-
IIS7下.NET4.0 网站UrlRewriter.dll重写无后缀路径 失效
解决方法: 1.添加通配符脚本映射,选择:C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll 2.找到和网站相对的连接池,选择 ...
-
erlang判断语法结构:if/case/guard
erlang 有好几种常用的判断结构语句,如 if.case.guard 等.文章将分别对 if / case /guard 的特点做介绍,以及用例说明 1.if 结构 if Condition 1 ...
-
简单OS(ucos超级精简版)——裸调度器【worldsing笔记】
简单原则少ROM,少RAM,任务完成就让出CPU,调度器描述: 1.按最大任务数轮番调度: 2.任务调用延时接口将让出CPU使用权,进入下一个任务调度: 3.用户任务都处于延时或是不使用CPU运行Id ...
-
【字母树+贪心】【HDU3460】【Ancient Printer】
题目大意: 一个打印机 只有 打印,删除,a-z.操作 给你一堆队名,如何才能操作次数最少输出全部 (字典树节点数-1)*2 输入,删除操作数 字符串数 printf操作数 最长字符串的长度 最后一个 ...
-
对bootstrap不同版本的总结
之前以为bootstrap2和bootstrap3没啥区别,无非就是功能增加了,简直是误区啊 bootstrap3与bootstrap2版本语法都不同啦 栅格写法 col-md-3/span3 文本效 ...
-
[LeetCode] Positions of Large Groups 大群组的位置
In a string S of lowercase letters, these letters form consecutive groups of the same character. For ...