JAVA编程规范大全

命名规范

  定义这个规范的目的是让项目中所有的文档都看起来像一个人写的,增加可读性,减少项目组中因为换人而带来的损失。(这些规范并不是一定要绝对遵守,但是一定要让程序有良好的可读性)

  Package 的命名

  Package 的名字应该都是由一个小写单词组成。

  Class 的命名

  Class 的名字必须由大写字母开头而其他字母都小写的单词组成

  Class 变量的命名

  变量的名字必须用一个小写字母开头。后面的单词用大写字母开头。

  Static Final 变量的命名

  Static Final 变量的名字应该都大写,并且指出完整含义。

  参数的命名

  参数的名字必须和变量的命名规范一致。

  数组的命名

  数组应该总是用下面的方式来命名:

  byte[] buffer;

  而不是:

  byte buffer[];

  方法的参数

  使用有意义的参数命名,如果可能的话,使用和要赋值的字段一样的名字:

  SetCounter(int size){

  this.size = size;

  }

  Java 文件样式

  所有的 Java(*.java) 文件都必须遵守如下的样式规则

  版权信息

  版权信息必须在 java 文件的开头,比如:

  /**

  * Copyright ® 2000 Shanghai XXX Co. Ltd.

  * All right reserved.

  */

  其他不需要出现在 javadoc 的信息也可以包含在这里。

  Package/Imports

  package 行要在 import 行之前,import 中标准的包名要在本地的包名之前,而且按照字母顺序排列。如果 import 行中包含了同一个包中的不同子目录,则应该用 * 来处理。

  package hotlava.net.stats;

  import java.io.*;

  import java.util.Observable;

  import hotlava.util.Application;

  这里 java.io.* 使用来代替InputStream and OutputStream 的。

  Class

  接下来的是类的注释,一般是用来解释类的。

  /**

  * A class representing a set of packet and byte counters

  * It is observable to allow it to be watched, but only

  * reports changes when the current set is complete

  */

  接下来是类定义,包含了在不同的行的 extends 和 implements

  public class CounterSet

  extends Observable

  implements Cloneable

  Class Fields

  接下来是类的成员变量:

  /**

  * Packet counters

  */

  protected int[] packets;

  public 的成员变量必须生成文档(JavaDoc)。proceted、private和 package 定义的成员变量如果名字含义明确的话,可以没有注释。

  存取方法

  接下来是类变量的存取的方法。它只是简单的用来将类的变量赋值获取值的话,可以简单的写在一行上。

  /**

  * Get the counters

  * @return an array containing the statistical data. This array has been

  * freshly allocated and can be modified by the caller.

  */

  public int[] getPackets() { return copyArray(packets, offset); }

  public int[] getBytes() { return copyArray(bytes, offset); }

  public int[] getPackets() { return packets; }

  public void setPackets(int[] packets) { this.packets = packets; }

  其它的方法不要写在一行上

  构造函数

  接下来是构造函数,它应该用递增的方式写(比如:参数多的写在后面)。

  访问类型 ("public", "private" 等.) 和 任何 "static", "final" 或 "synchronized" 应该在一行中,并且方法和参数另写一行,这样可以使方法和参数更易读。

  public

  CounterSet(int size){

  this.size = size;

  }

  克隆方法

  如果这个类是可以被克隆的,那么下一步就是 clone 方法:

  public

  Object clone() {

  try {

  CounterSet obj = (CounterSet)super.clone();

  obj.packets = (int[])packets.clone();

  obj.size = size;

  return obj;

  }catch(CloneNotSupportedException e) {

  throw new InternalError("Unexpected CloneNotSUpportedException: " + e.getMessage());

  }

  }

  类方法

  下面开始写类的方法:

  /**

  * Set the packet counters

  * (such as when restoring from a database)

  */

  protected final

  void setArray(int[] r1, int[] r2, int[] r3, int[] r4)

  throws IllegalArgumentException

  {

  //

  // Ensure the arrays are of equal size

  //

  if (r1.length != r2.length || r1.length != r3.length || r1.length != r4.length)

  throw new IllegalArgumentException("Arrays must be of the same size");

  System.arraycopy(r1, 0, r3, 0, r1.length);

  System.arraycopy(r2, 0, r4, 0, r1.length);

  }

  toString 方法

  无论如何,每一个类都应该定义 toString 方法:

  public

  String toString() {

  String retval = "CounterSet: ";

  for (int i = 0; i < data.length(); i++) {

  retval += data.bytes.toString();

  retval += data.packets.toString();

  }

  return retval;

  }

  }

  main 方法

  如果main(String[]) 方法已经定义了, 那么它应该写在类的底部.

  代码编写格式

  代码样式

  代码应该用 unix 的格式,而不是 windows 的(比如:回车变成回车+换行)

  文档化

  必须用 javadoc 来为类生成文档。不仅因为它是标准,这也是被各种 java 编译器都认可的方法。使用 @author 标记是不被推荐的,因为代码不应该是被个人拥有的。

  缩进

  缩进应该是每行2个空格. 不要在源文件中保存Tab字符. 在使用不同的源代码管理工具时Tab字符将因为用户设置的不同而扩展为不同的宽度.

  如果你使用 UltrEdit 作为你的 Java 源代码编辑器的话,你可以通过如下操作来禁止保存Tab字符, 方法是通过 UltrEdit中先设定 Tab 使用的长度室2个空格,然后用 Format|Tabs to Spaces 菜单将 Tab 转换为空格。

  页宽

  页宽应该设置为80字符. 源代码一般不会超过这个宽度, 并导致无法完整显示, 但这一设置也可以灵活调整. 在任何情况下, 超长的语句应该在一个逗号或者一个操作符后折行. 一条语句折行后, 应该比原来的语句再缩进2个字符.

  {} 对

  {} 中的语句应该单独作为一行. 例如, 下面的第1行是错误的, 第2行是正确的:

  if (i>0) { i ++ }; // 错误, { 和 } 在同一行

  if (i>0) {

  i ++

  }; // 正确, { 单独作为一行

  } 语句永远单独作为一行.

  如果 } 语句应该缩进到与其相对应的 { 那一行相对齐的位置。

  括号

  左括号和后一个字符之间不应该出现空格, 同样, 右括号和前一个字符之间也不应该出现空格. 下面的例子说明括号和空格的错误及正确使用:

  CallProc( AParameter ); // 错误

  CallProc(AParameter); // 正确

  不要在语句中使用无意义的括号. 括号只应该为达到某种目的而出现在源代码中。下面的例子说明错误和正确的用法:

  if ((I) = 42) { // 错误 - 括号毫无意义

  if (I == 42) or (J == 42) then // 正确 - 的确需要括号

java编程规范大全的更多相关文章

  1. JAVA编程规范(下)

    JAVA编程规范(下) 2016-03-27 6. 代码的格式化 6.1 对代码进行格式化时,要达到的目的 1.     通过代码分割成功能块和便于理解的代码段,使代码更容易阅读和理解: 2.     ...

  2. JAVA 编程规范(上)

    2016-03-20 J120-CHARLIEPAN JAVA 编程规范(上) 1.      应用范围 本规范应用于采用J2EE规范的项目中,所有项目中的JAVA代码(含JSP,SERVLET,JA ...

  3. Java编程规范(一)

    最近在看一本有关Java编程规范的书,书中精炼阐述了使用java语言时应该遵循的一些原则.接下来的一段时间我将在这里总结我的学习内容,也希望这一系列文章能够对有需要的人有所帮助. 不考虑任何编码规范的 ...

  4. Java编程规范(二)

    二.格式规范 在上一篇的java编程规范(一)中我们讲述了在Java编码中的一般原则,虽然这些原则并不涉及具体的代码规范,但是这些原则却是我们在Java开发过程中所应该遵循的规范与思想.今天我们将学习 ...

  5. FangDD Java编程规范

    我们采用<Oracle/Sun原生的Java编程规范>和<Google Java编程规范> Google Java编程风格指南 January 20, 2014 作者:Haws ...

  6. Java编程规范参考

    谷歌Java编程规范-原版 谷歌Java编程规范-中文翻译版 阿里巴巴Java编程规范 阿里巴巴Java编程规范-IDEA 插件 阿里巴巴Java编程规范-Eclipse 插件

  7. 乐字节Java变量与数据类型之一:Java编程规范,关键字与标识符

    大家好,我是乐字节的小乐,这次要给大家带来的是Java变量与数据类型.本文是第一集:Java编程规范,关键字与标识符. 一.编程规范 任何地方的名字都需要见名知意: 代码适当缩进 书写过程成对编程 对 ...

  8. 阿里巴巴Java编程规范考试

    阿里巴巴Java编程规范考试 今天在阿里云官网把阿里巴巴Java编程规范认证考试考过了, 写下这篇文章总结一下考试中需要注意的知识点, 主体内容还是要直接看规范: 编程规约 异常日志 单元测试 安全规 ...

  9. JAVA基础语法:java编程规范和常用数据类型(转载)

    JAVA基础语法:java编程规范和常用数据类型 摘要 本文主要介绍了最基本的java程序规则,和常用数据类型,其中侧重说了数组的一些操作. 面向java编程 java是纯面向对象语言,所有的程序都要 ...

随机推荐

  1. SpringMvc表单标签库

    HTML密码框 <td><form:label path="password">密码:</form:label></td><t ...

  2. date、cal和clear命令

    一.date命令 date命令的功能:date命令是显示或设置系统时间与日期. 很多shell脚本里面需要打印不同格式的时间或日期,以及要根据时间和日期执行操作.延时通常用于脚本执行过程中提供一段等待 ...

  3. More Effective C++: 05技术(29)

    29:引用计数 本章首先实现一个带引用计数String,然后逐步优化,介绍引用计数的常规实现. 实现引用计数的String,首先需要考虑:引用计数在哪存储.这个地方不能在String对象内部,因为需要 ...

  4. Word画线条5大技巧,简单实用!

    [Word画线条5大技巧,简单实用!]1.输入三个“=”,回车,就是一条双直线:2.输入三个“~”,回车,就是一条波浪线:3.输入三个“”回车,就是一条虚线:4.输入三个“-”,回车,就是一条直线:5 ...

  5. linux下的远程数据库(Oracle)中文乱码问题

    适用于本地客户端(PLSQL Developer )访问远程数据库时,查询结果出现的乱码,当在远程数据库上查询结果时显示正常. 1.查询远程数据库的编码: select userenv('langua ...

  6. eclipse Some projects cannot be imported because they already exist in the workspace

    archive file 档案文件 删除对应的文件即可

  7. KiCad EDA 5.1.4 发布了

    KiCad EDA 5.1.4 发布了 KiCad EDA 自豪地宣布 KiCad 5 系列最新稳定版发布.5.1.4 稳定版修复了来自 5.1.2 和 5.1.3 版本的关键错误修复和其他一些小改进 ...

  8. 阿里开源新一代 AI 算法模型,由达摩院90后科学家研发

    最炫的技术新知.最热门的大咖公开课.最有趣的开发者活动.最实用的工具干货,就在<开发者必读>! 每日集成开发者社区精品内容,你身边的技术资讯管家. 每日头条 阿里开源新一代 AI 算法模型 ...

  9. HZOJ 老司机的狂欢

    比较神仙的一道题. 第一问还比较简单一点: t是否可行是单调的,考虑二分. 考虑对于两个人i,j合法的条件,设x(i)<x(j),那么$x(i)+\frac {a(i)*t^2}{2} < ...

  10. python 列表对象的增减