目的:能够在编码过程中实现规范化,为以后的程序开发中养成良好的行为习惯
最近做的一个系统,做完之后发现命名有些不够规范,所以想要规范一下命名,这样才能使项目目录更规范与整齐,网上发现该详细的命名规范博文.但是有些命名规范已经有些不在适合,参考该博文的基础上,进行了修改.
在此感谢该博主,原文地址---http://www.cnblogs.com/xwdreamer/archive/2012/02/15/2352434.html
包命名规范: 目的:包的命名规范应当体现出项目资源良好的划分
原因 :Java包的名字都是由小写单词组成。但是由于Java面向对象编程的特性,每一名Java程序员都 可以编写属于自己的Java包,为了保障每个Java包命名的唯一性,在最新的Java编程规范中,要求程序员在自己定义的包的名称之前加上唯一的前缀。 由于互联网上的域名称是不会重复的,所以程序员一般采用自己在互联网上的域名称作为自己程序包的唯一前缀。 servlet类所在包命名规范:域名类型.域名.项目名称.web.servlet 例如:com.baidu.web.servlet 自定义标签类所在包命名规范:域名类型.域名.项目名称.web.tags 例如:com.baidu.web.tags 过滤器类所在包命名规范:域名类型.域名.项目名称.web.filter 例如:com.baidu.web.filter Action类所在包命名规范:域名类型.域名.项目名称.web.action 例如:com.baidu.web.action ActionForm类所在包命名规范:域名类型.域名.项目名称.web.form 例如:com.baidu.web.form Javabean所在包命名规范:域名类型.域名.项目名称.web.service.impl 例如:com.baidu.web.service.impl Javabean实现接口命名规范:域名类型.域名.项目名称.web.service 例如:com.baidu.web.service DAO类所在包命名规范:域名类型.域名.项目名称.dao.impl 例如:com.baidu.dao.impl DAO类所实现的接口在包中命名规范:域名类型.域名.项目名称.dao 例如:com.baidu.dao POJO类与hbm文件所在包命名规范:域名类型.域名.项目名称.dao.hbm 例如:com.baidu.dao.hbm 全局公共类、接口类所在包命名规范:域名类型.域名.项目名称.global 例如:com.baidu.global 全局工具类所在包命名规范:域名类型.域名.项目名称.util 例如:com.baidu.util
基本命名规范: 类命名
原因:Java类名通常以大写字母开头,如果类名称由多个单词组成,则每个单词的首字母均应为大 写例如TestPage;如果类名称中包含单词缩写,则这个所写词的每个字母均应大写,如:XMLExample,还有一点命名技巧就是由于类是设计用来 代表对象的,所以在命名类时应尽量选择名词。
命名规范:以大写字母开头,如果有多个单词,每个单词头字母大写 例如:StudentInfo 接口命名: 命名规范:以大写字母"I"开头,如果有多个单词,每个单词头字母大写 例如:IStudentInfo 接口实现类命名: 命名规范:将实现的接口名称的首字母"I"去掉,以"Impl作为结尾",如果有多个单词,每个单词头字母大写。 例如:StudentInfoImpl
J2EE+SSH框架命名规范
servlet类命名: 命名规范:以Servlet单词结尾 例如:LoginServlet POJO命名: 以大写字母开头,如果有多个单词,每个单词头字母大写 DAO类命名: 以大写字母开头,如果有多个单词,每个单词头字母大写 Action类命名: 命名规范:Action的命名以POJO名称来制定,POJO名称Action 例如: 一个POJO名称为Diary,其对应的action为DiaryAction ActionForm类命名: 命名规范:ActionForm的命名以POJO名称来制定,POJO名称Form 例如: 一个POJO名称为Diary,其对应的actioForm为DiaryForm 业务逻辑接口命名: 命名规范:业务逻辑接口的命名以POJO名称来制定,IPOJO名称Service 例如: 一个POJO名称为Diary,其对应的业务逻辑接口为IDiaryService 业务逻辑实现类命名: 命名规范:业务逻辑接口实现类的命名以POJO名称来制定 例如: 一个POJO名称为Diary,对应的业务逻辑接口实现类名为DiaryServiceImpl 类变量命名: 命名规范:变量名首字母必须小写,如果该变量名有多个单词组成,后面的单 词首字母大写,单词与单词之间不要使用"_"做连接,变量名访问控制必须为私有, 可以对其增加setter与getter方法。 例如:
private int studentAge;
public int getStudentAge(){
return studentAge;
}
public void setStudentAge(int studentAge) {
this.studentAge=studentAge;
}
常量命名: 命名规范:所有字母大写,如果有多个单词组成,单词与单词之间以” _“隔开。而 且该变量必须是公共、静态、final类型 例如:public static final String USER_NAME=”userName“; 方法命名 命名规范:首字母必须小写,如果该变量名有多个单词组成,后面的单词首字母 大写,单词与单词之间不要使用"_"做连接。单词不要使用名词。 例如:public int checkLogin(String name,String pwd){}
注释规范:
目的:注释规范是整个开发规范中最为重要的组成部分,必须严格执行。
类的注释: 作用:注释整个类,简单概述该类作用。 书写规范:类的注释必须写在该类的声明语法之前。在注释中要描述该类的基 本作用,作者,日期,版本,公司名称,版权声明。 格式:
/* *
* 类功能描述:(大致描述类的功能)
* @author:编写者名称
*
* @version: 类文件的版本号 从1.0开始(自己确定版本号的增改
* 情况), 修改情况(修改时间、作者、改动情况)
*
* @see 包名.参考类名 (列出父类,引入类,每个类占一行),如果有
* 可省略
* 相关数据如:(便于理解本类的一些常量数据及某些数据的格式
* 或认为比较重要的数据,如果没有可省略)
*/
类的声明语法 例如:
/**
* <p>Title:管理员模块数据处理类 </p>
* <p>Description: 两个数相加</p>
* <p>Copyright: Copyright (c) 2007</p>
* <p>Company:华腾软件公司</p>
*
* @author 童金虎
*
* @version $Revision: 1.7 $ $Date: 2007/07/08$
*/
public class AdminDAO
变量、常量注释: 作用:简单描述该变量的意义。 书写规范:变量注释必须写在变量定义之前,简单描述其代表的意义。 格式: /** * 变量功能描述:(大致描述变量的功能) */ 例如:
/**
*定义年龄变量
*/
public int age;
方法注释: 作用:对该方法功能简单描述,其参数、返回值意义的注解。 书写规范:方法注释必须写在方法定义之前。该注释包括:方法其功能的简单 描述,方法的参数、返回值类型、返回值意义简单的描述。 格式:
/**
* 方法功能说明
* @param args (参数类型可以写在参数后,也可以省
* 略。每个参数占一行)
* @return 输出参数(多种情况写在同一行)
* @see 类#参考方法 (与此方法有调用关系的方法供参
* 考,不必每个方法都完整列出,要选择有意义的,每个
* 方法占一行)
* @exception 异常处理类(方法中能够引发的异常,每
* 个异常占一行)
*/
例如:
/**
* 修改管理员密码
* @param adminId 管理员编号
* @param oldPassword 旧密码
* @param password 新密码
* @return boolean 是否编辑成功
* @throws UserException
* @throws ServiceException
*/
public booleaneditAdminPassword(int adminId,String oldPassword,
String password) throws UserException,ServiceException;
Jsp页面命名:
命名规范:jsp页面名称要以小写字母开头,如果有多个单词组成,单词以'_'连接。名称要体现出该页面的意义,最好能够与模块名称联系在一起。 例如: login.jsp --登录页面 register.jsp --注册页面 message.jsp --客户留言页面
user_update.jsp --多个单词
user_insert.jsp --多个单词
J2EE项目工程文件夹组织规范:
目的:规范学员web应用程序的资源组织形式,形成良好的文件组织习惯。文件的组织形式应当体现模块的划分。 根据eclipse工具的特征,项目的目录结构为: src ----存放java文件 WebRoot |--images --存放web程序所需的公共图片 |--css --存放web程序所需的公共样式表 |--js --存放web程序所需的公共js文件 |--commons --存放web程序所需的公共文件 |--功能模块文件夹(存放与某个功能模块相关的资源) |--images --存放与该功能模块相关的图片 |--css --存放与该模块相关的样式表文件 |--js --存放与该模块相关的js文件 |--jsp、html页面 |--WEB-INF |--classes |--lib |--tld文件
J2EE项目提交规范
目的:项目完成时要将项目作为一个产品交付用户,良好的项目组织规范可以使用户可以方便的找寻项目中需要的资源,同时也是一个公司专业性的体现。项目提交时,要按照下列文件格式进行提交。 项目主文件夹: 作用:存放项目其他资源文件。 命名规范:时间_班级编号_第X小组。 例如:070706_GS2T18_第四小组。 项目主文件夹下面包括以下文件夹和文件: |--src:保存.java文件。 |--database:保存数据库的脚本文件或者数据库备份文件。 |--source:保存eclipse工程中WebRoot目录下的所有文件。 |--depend:保存编译该程序必须依赖的其他jar文件。 |--javadoc:保存所有类生成的javadoc api文档。 |--war:保存程序的归档文件 |--xx.war:已经打包好的工程文件,可以直接运行。 |--project:保存开发项目原工程代码及文件。 |--产品说明书.doc:图文方式展现该产品使用方法。 |--build.xml:ant脚本,用于生成运行的war文件。 |--项目解说.ppt:进行项目讲解的ppt(ppt仅供在校模拟项目使用,不用于其他商业用途) 注:一个完整的项目中,数据库必须有一定量的有效的测试数据来支持该程序的运行