做为一名全干打字员,干活时常常会被要求使用各类各样的语言去实现各类各样的需求,来回切换起来写的代码就会或多或少有点不规范。今天咱们以JAVA为例,讲讲在代码中,咱们须要注意的某些规范。(本文标准依赖于阿里巴巴的JAVA开发代码规范)java
如下举出本猿在工做中经常出现的问题,包括但不只限于:安全
在 if/else/for/while/do
语句中必须使用大括号,即便只有一行代码,避免使用下面的形式:多线程
if(condition) statements;
不少童鞋喜欢使用 Apache Beanutils
进行属性的copy, Apache BeanUtils
性能较差,咱们应该尽可能避免使用,可使用其余方案好比 Spring BeanUtils
, Cglib BeanCopier
。并发
TestObject a = new TestObject(); TestObject b = new TestObject(); a.setX(b.getX()); a.setY(b.getY());
全部的覆写方法,都必需要加上 @Override
注解。app
方法名、参数名、成员变量、局部变量都应该统一使用 lowerCamelCase
,类名使用 UpperCamelCase
风格,听从驼峰命名的标准,尽可能避免如 _
-
等字符链接,但如下情形例外:(领域模型的相关命名)DO / BO / DTO / VO / DAO。另外,类都应该加上建立者的信息,方法名也应该加上对应的参数及用途说明。dom
常量命名应该所有大写,但此间使用下划线隔开,力求语义表达完整清楚,不要嫌名字长。ide
首先 Random
示例包括 java.util.Random
或者 Math.random()
,咱们应该避免其被多线程使用,虽然共享该实例是线程安全的,但会因竞争统一 seed
致使性能降低。高并发
ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("demo-pool-%d").build(); ExecutorService singleThreadPool = new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy()); singleThreadPool.execute(()-> System.out.println(Thread.currentThread().getName())); singleThreadPool.shutdown();
+字符串拼接性能
在循环体内,咱们应当使用 StringBuilder
的 append
方法进行字符串的链接。ui
反例: String result; for (String string : tagNameList) { result = result + string; } 正例: StringBuilder stringBuilder = new StringBuilder(); for (String string : tagNameList) { stringBuilder.append(string); } String result = stringBuilder.toString();
不少人喜欢使用下面的代码进行 equals
判断是否为某个值:
public static final String type = "FOOD"; if(Object.equals(type)){ //do something }
对象中的equals很容易抛空指针异常,因此咱们应该尽可能使用常量或者肯定有值的对象来调用equals。
public void f(String str){ String inner = "hi"; if(inner.equals(str)){ System.out.println("hello world"); } }
咱们每每在集合初始化的时候忘记指定集合的初始值大小,在高并发的状况下,这样极可能会形成内存的使用不当引发一系列的问题。因此在使用诸如 HashMap
的时候尽可能指定初始值的大小。
反例: Map<String, String> map = new HashMap<String, String>(); 正例: Map<String, String> map = new HashMap<String, String>(16);
方法内部应当使用单行注释,在被注释语句的上方另起一行,使用 //
进行注释,多行注释则使用 /* */
,强迫症下应注意与代码对齐。
public void method() { // Put single line comment above code. (Note: align '//' comment with code) int a = 3; /** * Some description about follow code. (Note: align '/**' comment with code) */ int b = 4; }
在每个switch块内,每个case都必须经过 break/return
来终止或者是注释说明程序继续执行到某一个case为止,而且都应该包含一个 default
语句放在最后,即使没有代码。
switch( x ){ case 1 : break ; case 2 : break ; default : }
虽然咱们每每写出的代码可能不是很高效、简洁,可是咱们必定注意代码的可读性,毕竟代码除了机器看以外,也是给人看的。
送福利送福利啦,本猿最近得到了三张 5QB
的抵用卷,本着蚊子再小也是肉的原则,把它送给在公众号上留言的前三位童鞋,留言的前三位童鞋看到后记得在后台留下QQ号联系打字员大大领取福利哟~