Java包行業命名規則習慣

轉一個J2EE開發時的包命名規則,養成良好的開發習慣

代碼編寫規範目的:能夠在編碼過程中實現規範化,爲以後的程序開發中養成良好的行爲習慣。
代碼編寫規範使用範圍:J2EE項目開發。
包命名規範:
目的:包的命名規範應當體現出項目資源良好的劃分

servlet類所在包命名規範:公司名稱.開發組名稱.項目名稱.web.servlet
例如:net.linkcn.web.servlet

自定義標籤類所在包命名規範:公司名稱.開發組名稱.項目名稱.web.tags
例如:net.linkcn.web.tags

過濾器類所在包命名規範:公司名稱.開發組名稱.項目名稱.web.filter
例如:net.linkcn.web.filter

Action類所在包命名規範:公司名稱.開發組名稱.項目名稱.web.struts.action
例如:net.linkcn.web.struts.action

ActionForm類所在包命名規範:公司名稱.開發組名稱.項目名稱.web.struts.form
例如:net.linkcn.web.struts.form

Javabean所在包命名規範:公司名稱.開發組名稱.項目名稱.web.struts.service.impl
例如:net.linkcn.web.service.impl

Javabean實現接口命名規範:公司名稱.開發組名稱.項目名稱.web.service
例如:net.linkcn.web.service

DAO類所在包命名規範:公司名稱.開發組名稱.項目名稱.dao.impl
例如:net.linkcn.dao.impl

DAO類所實現的接口在包中命名規範:公司名稱.開發組名稱.項目名稱.dao
例如:net.linkcn.dao

POJO類與hbm文件所在包命名規範:公司名稱.開發組名稱.項目名稱.dao.hbm
例如:net.linkcn.dao.hbm

全局公共類、接口類所在包命名規範:公司名稱.開發組名稱.項目名稱.global
例如:net.linkcn.global

全局工具類所在包命名規範:公司名稱.開發組名稱.項目名稱.util
例如:net.linkcn.util

類命名規範
基本命名規範:

類、接口命名

命名規範:以大寫字母開頭,如果有多個單詞,每個單詞頭字母大寫
例如:StudentInfo
接口命名

命名規範:以大寫字母”I”開頭,如果有多個單詞,每個單詞頭字母大寫
例如:IStudentInfo

接口實現類命名:
命名規範:將實現的接口名稱的首字母”I”去掉,以”Impl作爲結尾”,如果有多個單詞,每個單詞頭字母大寫。
例如:StudentInfoImpl

J2EE+SSH框架命名規範
servlet類命名:
命名規範:以Servlet單詞結尾
例如:LoginServlet

POJO命名:
使用hibernate自動生成的類即可

DAO類命名:
使用hibernate自動生成的類即可

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){}

註釋規範:註釋規範是整個開發規範中最爲重要的組成部分,必須嚴格執行。

類的註釋:
作用:註釋整個類,簡單概述該類作用。
書寫規範:類的註釋必須寫在該類的聲明語法之前。在註釋中要描述該類的基 本作用,作者,日期,版本,公司名稱,版權聲明。
格式:

類的聲明語法

例如:

public class AdminDAO

變量、常量註釋:
作用:簡單描述該變量的意義。
書寫規範:變量註釋必須寫在變量定義之前,簡單描述其代表的意義。
格式:

例如:

public int age;
方法註釋:
作用:對該方法功能簡單描述,其參數、返回值意義的註解。
書寫規範:方法註釋必須寫在方法定義之前。該註釋包括:方法其功能的簡單 描述,方法的參數、返回值類型、返回值意義簡單的描述。
格式:

例如:

public booleaneditAdminPassword(int adminId,String oldPassword,
String password) throws UserException,ServiceException;

Jsp頁面命名:
命名規範:jsp頁面名稱要以小寫字母開頭,如果有多個單詞組成,後面的單詞以 大寫字母開頭。名稱要體現出該頁面的意義,最好能夠與模塊名稱聯繫在一起。
例如:
login.jsp –登錄頁面
register.jsp –註冊頁面
message.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僅供在校模擬項目使用,不用於其他商業用途)
注:一個完整的項目中,數據庫必須有一定量的有效的測試數據來支持該程序的運行

包的命名 
Java包的名字都是由小寫單詞組成。但是由於Java面向對象編程的特性,每一名Java程序員都可以編寫屬於自己的Java包,爲了保障每個 Java包命名的唯一性,在最新的Java編程規範中,要求程序員在自己定義的包的名稱之前加上唯一的前綴。由於互聯網上的域名稱是不會重複的,所以程序 員一般採用自己在互聯網上的域名稱作爲自己程序包的唯一前綴。
例如: net.frontfree.javagroup

類的命名
類的名字必須由大寫字母開頭而單詞中的其他字母均爲小寫;如果類名稱由多個單詞組成,則每個單詞的首字母均應爲大寫例如TestPage;如果類名 稱中包含單詞縮寫,則這個所寫詞的每個字母均應大寫,如:XMLExample,還有一點命名技巧就是由於類是設計用來代表對象的,所以在命名類時應儘量 選擇名詞。   
例如: Circle

方法的命名
方法的名字的第一個單詞應以小寫字母作爲開頭,後面的單詞則用大寫字母開頭。
例如: sendMessge

常量的命名
常量的名字應該都使用大寫字母,並且指出該常量完整含義。如果一個常量名稱由多個單詞組成,則應該用下劃線來分割這些單詞。
例如: MAX_VALUE

參數的命名
參數的命名規範和方法的命名規範相同,而且爲了避免閱讀程序時造成迷惑,請在儘量保證參數名稱爲一個單詞的情況下使參數的命名儘可能明確。

Javadoc註釋
Java除了可以採用我們常見的註釋方式之外,Java語言規範還定義了一種特殊的註釋,也就是我們所說的Javadoc註釋,它是用來記錄我們代 碼中的API的。Javadoc註釋是一種多行註釋,以結束,註釋可以包含一些HTML標記符和專門的關鍵詞。使用Javadoc 註釋的好處是編寫的註釋可以被自動轉爲在線文檔,省去了單獨編寫程序文檔的麻煩。
例如:

在每個程序的最開始部分,一般都用Javadoc註釋對程序的總體描述以及版權信息,之後在主程序中可以爲每個類、接口、方法、字段添加 Javadoc註釋,每個註釋的開頭部分先用一句話概括該類、接口、方法、字段所完成的功能,這句話應單獨佔據一行以突出其概括作用,在這句話後面可以跟 隨更加詳細的描述段落。在描述性段落之後還可以跟隨一些以Javadoc註釋標籤開頭的特殊段落,例如上面例子中的@auther和@version,這 些段落將在生成文檔中以特定方式顯示。

變量和常量命名
變量命名的方法採用匈牙利命名法,基本結構爲scope_typeVariableName,它使用3字符前綴來表示數據類型,3個字符的前綴必須 小寫,前綴後面是由表意性強的一個單詞或多個單詞組成的名字,而且每個單詞的首寫字母大寫,其它字母小寫,這樣保證了對變量名能夠進行正確的斷句。例如, 定義一個整形變量,用來記錄文檔數量:intDocCount,其中int表明數據類型,後面爲表意的英文名,每個單詞首字母大寫。這樣,在一個變量名就 可以反映出變量類型和變量所存儲的值的意義兩方面內容,這使得代碼語句可讀性強、更加容易理解。byte、int、char、long、float、 double、boolean和short。
變量類型和首字母對照關係如下表:
數據類型/對象類型 / 變量前綴 / 備註
byte bye
char chr
float flt
boolean bln 做布爾變量時,使用bln
Integer/int int
String str
Single sng
short sht
Long/long lng
Double/double dbl
Currency cur
Variant bln astr obj vnt 做布爾變量用時,用bln,做字符串數組用時,用astr,做爲對象使用時,用obj,不確定時,用vnt。
對於數組,在數據類型的前綴前再增加一個a,例如字符串數組爲astr。對於在多個函數內都要使用的全局變量,在前面再增加“g_”。例如一個全局的字符串變量:g_strUserInfo。

在變量命名時要注意以下幾點:
· 選擇有意義的名字,注意每個單詞首字母要大寫。

· 在一段函數中不使用同一個變量表示前後意義不同的兩個數值。

· i、j、k等只作爲小型循環的循環索引變量。

· 避免用Flag來命名狀態變量。

· 用Is來命名邏輯變量,如:blnFileIsFound。通過這種給布爾變量肯定形式的命名方式,使得其它開發人員能夠更爲清楚
的理解布爾變量所代表的意義。

· 如果需要的話,在變量最後附加計算限定詞,如:curSalesSum。

· 命名不相包含,curSales和curSalesSum。

· Static Final 變量的名字應該都大寫,並且指出完整含義。

· 如果需要對變量名進行縮寫時,一定要注意整個代碼中縮寫規則的一致性。例如,如果在代碼的某些區域中使用intCnt,而在另一些區域中又使用intCount,就會給代碼增加不必要的複雜性。建議變量名中儘量不要出現縮寫。

· 通過在結尾處放置一個量詞,就可創建更加統一的變量,它們更容易理解,也更容易搜索。例如,請使用 strCustomerFirst和strCustomerLast,而不要使用strFirstCustomer和strLastCustomer。常 用的量詞後綴有:First(一組變量中的第一個)、Last(一組變量中的最後一個)、Next(一組變量中的下一個變量)、Prev(一組變量中的上 一個)、Cur(一組變量中的當前變量)。

· 爲每個變量選擇最佳的數據類型,這樣即能減少對內存的需求量,加快代碼的執行速度,又會降低出錯的可能性。用於變量的數據類型可能會影響該變量進行計算所產生的結果。在這種情況下,編譯器不會產生運行期錯誤,它只是迫使該值符合數據類型的要求。這類問題極難查找。

· 儘量縮小變量的作用域。如果變量的作用域大於它應有的範圍,變量可繼續存在,並且在不再需要該變量後的很長時間內仍然佔用資源。它們的主要問題是,任何類 中的任何方法都能對它們進行修改,並且很難跟蹤究竟是何處進行修改的。佔用資源是作用域涉及的一個重要問題。對變量來說,儘量縮小作用域將會對應用程序的 可靠性產生巨大的影響。
關於常量的命名方法,在JAVA代碼中,無論什麼時候,均提倡應用常量取代數字、固定字符串。也就是說,程序中除0,1以外,儘量不應該出現其他數 字。常量可以集中在程序開始部分定義或者更寬的作用域內,名字應該都使用大寫字母,並且指出該常量完整含義。如果一個常量名稱由多個單詞組成,則應該用下 劃線“_”來分割這些單詞如:NUM_DAYS_IN_WEEK、MAX_VALUE。
文章來源:點擊打開鏈接

發佈了305 篇原創文章 · 獲贊 11 · 訪問量 26萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章