有些編程規範,學編程第一天就應該瞭解,這些習慣比你多學兩章知識來的更爲實際,他們甚至可能會直接影響你的編程生涯,因此,不要一開始以爲這些習慣都不重要,有不少同窗認爲等到技術成熟的時候再考慮它們,卻不知,壞習慣一旦養成須要花費多大的經歷才能更正。一開始就對本身要求嚴格一些,慢慢的養成習慣,卻也不以爲這些規範是束縛,而認爲是天經地義的事情。 java
好的編程命名習慣不止是能夠提升代碼的可讀性,其實還能夠大大提升你的開發效率,例如,Android中各類控件的命名,好的命名可讓你快速的在Activity中找到所要引用的控件。不規則的命名會給本身形成沒必要要的混淆,須要花費一些時間區分這些命名,另外規則的命名還可能會預防命名重複的問題。 程序員
這些規則不是靠本身死記硬背出來的,一開始養成好習慣會流淌在程序員的血液裏,堅持從第一行代碼開始,嚴格按照命名規範來執行,長此以往就會以爲這是一件十分正常和合理的事情,一開始是痛苦的,卻也是值得的。 web
怎麼纔算是合理的命名、好的編程習慣呢,本身認爲的可不必定是合理的,咱們須要找到權威的解釋,能夠參考官方給出的命名規範和格式,也能夠參考一些大公司的編程規範,絕對會讓你受益不淺。網上一些資料也是能夠參考的,我整理了一些Android開發方面須要注意的命名和編程規範,你們能夠參考一下,也能夠發表本身的見解,豐富這一文檔。 數據庫
1.java代碼中不出現中文,最多註釋中能夠出現中文(儘可能不要用拼音命名啊,那樣顯得太low了!) 編程
2.局部變量命名、靜態成員變量命名
只能包含字母,單詞首字母出第一個外,都爲大寫,其餘字母都爲小寫。 app
3.常量命名
只能包含字母和_,字母所有大寫,單詞之間用_隔開。(API_KEY) ide
4.layout中的id命名
命名模式爲:view縮寫_模塊名稱_view的邏輯名稱(這個比較重要啊!很經常使用的!能夠findViewById()中快速找到控件) 工具
view的縮寫詳情以下: 佈局
LayoutView:lv 單元測試
RelativeView:rv
TextView:tv
ImageView:iv
ImageButton:im
Button:btn
5.activity中的view變量命名
命名模式爲:邏輯名稱+view縮寫(mUserNameTv)
建議:若是layout文件很複雜,建議將layout分紅多個模塊,每一個模塊定義一個moduleViewHolder,其成員變量包含所屬view
6.strings.xml中的id命名
命名模式:activity名稱_功能模塊名稱_邏輯名稱/activity名稱_邏輯名稱/common_邏輯名稱
strings.xml中,使用activity名稱註釋,將文件內容區分開來。
7.drawable中的圖片命名
命名模式:activity名稱_邏輯名稱/common_邏輯名稱
8.styles.xml:將layout中不斷重現的style提煉出通用的style通用組件,放到styles.xml中;
9.使用layer-list和selector
10.圖片儘可能分拆成多個可重用的圖片
11.服務端能夠實現的,就不要放在客戶端
12.引用第三方庫要慎重,避免應用大容量的第三方庫,致使客戶端包很是大
13.處理應用全局異常和錯誤,將錯誤以郵件的形式發送給服務端
14.圖片的.9處理(保證拉伸不變形,作背景圖片的一半要處理)
15.使用靜態變量方式實現界面間共享要慎重
16.Log(系統名稱 模塊名稱 接口名稱,詳細描述)
17.單元測試(邏輯測試、界面測試)
18.不要重用父類的handler,對應一個類的handler也不該該讓其子類用到,不然會致使message.what衝突
19.activity中在一個View.OnClickListener中處理全部的邏輯(switch分支判斷處理)
20.strings.xml中使用%1$s實現字符串的通配
21.若是多個Activity中包含共同的UI處理,那麼能夠提煉一個CommonActivity,把通用部分叫由它來處理,其餘activity只要繼承它便可
22.使用button+activitgroup實現tab效果時,使用Button.setSelected(true),確保按鈕處於選擇狀態,並使activitygroup的當前activity與該button對應
23.若是所開發的爲通用組件,爲避免衝突,將drawable/layout/menu/values目錄下的文件名增長前綴
24.數據必定要效驗,例如字符型轉數字型,若是轉換失敗必定要有缺省值;服務端響應數據是否有效判斷;
25.同一個客戶端若是要放在不一樣的市場,並且要統計各個市場下載及使用數據時針對不一樣的客戶端打不一樣的包,惟一的區別是versionName,apk文件名爲versionName.apk。在升級時,要將本身的versionCode和versionName一併傳給服務端,若是須要升級,則下載versionName相對應的apk
關因而否要強制升級:
1).無論何種狀況都強制升級
2).判斷用戶的版本和當前最新版本,若是兼容則強制升級,不然可選;
26.有的按鈕要避免重複點擊
下面是網上的資料,頗有必要看一看哦!真的頗有用!
標識符命名法
標識符命名法最要有四種:
1 駝峯(Camel)命名法:又稱小駝峯命名法,除首單詞外,其他全部單詞的第一個字母大寫。
2 帕斯卡(pascal)命名法:又稱大駝峯命名法,全部單詞的第一個字母大寫
3 下劃線命名法:單詞與單詞間用下劃線作間隔。
4 匈牙利命名法:普遍應用於微軟編程環境中,在以Pascal命名法的變量前附加小寫序列說明該變量的類型。 量的取名方式爲:<scope_> + <prefix_> + <qualifier>範圍前綴,類型前綴,限定詞。
我的以爲標識符命名原則:儘量的用最少的字符而又能完整的表達標識符的含義。
英文縮寫原則:
1 較短的單詞可經過去掉「元音」造成縮寫
2 較長的單詞可取單詞的頭幾個字母造成縮寫
3 此外還有一些約定成俗的英文單詞縮寫.
下面爲常見的英文單詞縮寫:
名稱 |
縮寫 |
icon |
ic (主要用在app的圖標) |
color |
cl(主要用於顏色值) |
divider |
di(主要用於分隔線,不只包括Listview中的divider,還包括普通佈局中的線) |
selector |
sl(主要用於某一view多種狀態,不只包括Listview中的selector,還包括按鈕的selector) |
average |
avg |
background |
Bg(主要用於佈局和子佈局的背景) |
buffer |
buf |
control |
ctrl |
delete |
del |
document |
doc |
error |
err |
escape |
esc |
increment |
inc |
infomation |
info |
initial |
init |
image |
img |
Internationalization |
I18N |
length |
len |
library |
lib |
message |
msg |
password- |
pwd |
position |
pos |
server |
srv |
string |
str |
temp |
tmp |
window |
wnd(win) |
程序中使用單詞縮寫原則:不要用縮寫,除非該縮寫是約定俗成的。
命名規範:
1 包(packages): 採用反域名命名規則,所有使用小寫字母。一級包名爲com,二級包名爲xx(能夠是公司或則我的的隨便),三級包名根據應用進行命名,四級包名爲模塊名或層級名
包名 |
此包中包含 |
com.xx.應用名稱縮寫.activities |
頁面用到的Activity類 (activities層級名用戶界面層) |
com.xx.應用名稱縮寫.base |
頁面中每一個Activity類共享的能夠寫成一個i額BaseActivity類 (基礎共享的類) |
com.xx.應用名稱縮寫.adapter |
頁面用到的Adapter類 (適配器的類) |
com.xx.應用名稱縮寫.tools |
此包中包含:公共工具方法類(tools模塊名) |
com.xx.應用名稱縮寫.bean (或則 com.xx.應用名稱縮寫.unity ) |
此包中包含:元素類 |
com.xx.應用名稱縮寫.db |
數據庫操做類 |
com.xx.應用名稱縮寫.view (或則 com.xx.應用名稱縮寫.ui ) |
自定義的View類等 |
com.xx.應用名稱縮寫.service |
Service服務 |
com.xx.應用名稱縮寫.broadcast |
Broadcast服務 |
2 類(classes):名詞,採用大駝峯命名法,儘可能避免縮寫,除非該縮寫是衆所周知的, 好比HTML,URL,若是類名稱中包含單詞縮寫,則單詞縮寫的每一個字母均應大寫。
類 |
描述 |
例如 |
activity 類 |
Aty或者Activity爲後綴標識 |
歡迎頁面類WelcomeAty.或者WelcomeActivity |
Adapter類 |
Adp或者Adapte 爲後綴標識 |
新聞詳情適配器NewtDetailAdp或則直接 NewDetailAdapter |
解析類 |
Hlr爲後綴標識 |
首頁解析類HomePosterHlr |
公共方法類 |
Tools或Manager爲後綴標識 |
線程池管理類:ThreadPoolManager |
數據庫類 |
以DBHelper後綴標識 |
新聞數據庫:NewDBHelper |
Service類 |
以Service爲後綴標識 |
時間服務TimeService |
BroadcastReceive類 |
以Broadcast爲後綴標識 |
時間通知TimeBroadcast |
ContentProvider |
以Provider爲後綴標識 |
|
直接寫的共享基礎類 |
以Base開頭 |
BaseActivity,BaseFragment |
方法 |
說明 |
initXX() |
初始化相關方法,使用init爲前綴標識,如初始化佈局initView() |
isXX() |
checkXX()方法返回值爲boolean型的請使用is或check爲前綴標識 |
getXX() |
返回某個值的方法,使用get爲前綴標識 |
processXX() |
對數據進行處理的方法,儘可能使用process爲前綴標識 |
displayXX() |
彈出提示框和提示信息,使用display爲前綴標識 |
saveXX() |
與保存數據相關的,使用sav爲e前綴標識 |
resetXX() |
對數據重組的,使用reset前綴標識 |
clearXX() |
清除數據相關的 |
removeXXX() |
清除數據相關的 |
drawXXX() |
繪製數據或效果相關的,使用draw前綴標識 |
命名模式:activity名稱_邏輯名稱/common_邏輯名稱
若是有多種形態如按鈕等除外如btn_xx.xml(selector)
名稱 |
功能 |
btn_xx |
按鈕圖片使用btn_總體效果(selector) |
btn_xx_normal |
按鈕圖片使用btn_正常狀況效果 |
btn_xx_press |
按鈕圖片使用btn_點擊時候效果 |
bg_head |
背景圖片使用bg_功能_說明 |
def_search_cell |
默認圖片使用def_功能_說明 |
icon_more_help |
圖標圖片使用icon_功能_說明 |
seg_list_line |
具備分隔特徵的圖片使用seg_功能_說明 |
sel_ok |
選擇圖標使用sel_功能_說明 |
命名後綴:
後綴 |
說明 |
unit |
在使用xml的tilemode來配圖片時,element圖片使用此後綴 |
nor |
圖片的狀態,表明普通狀態 |
hl |
圖片的狀態,表明高亮狀態 |
press |
圖片的狀態,表明按下狀態 |
select |
圖片的狀態,表明其所佔的view被選中 |
unselect |
圖片的狀態,表明其所佔的view沒有被選中 |
8 資源佈局文件(XML文件(layout佈局文件)):
所有小寫,採用下劃線命名法
1).contentview命名, Activity默認佈局,以去掉後綴的Activity類進行命名。不加後綴:
功能模塊.xml
例如:main.xml、more.xml、settings.xml
或則:activity_ 功能模塊 .xml例如:activity_main.xml、activity_more.xml
2).Dialog命名:dialog_描述.xml
例如:dlg_hint.xml
2).PopupWindow命名:ppw_描述.xml
例如:ppw _info.xml
3). 列表項命名listitem_描述.xml
例如:listitem_city.xml
4).包含項:include_模塊.xml
例如:include_head.xml、include_bottom.xml
5).adapter的子佈局:功能模塊_item.xml
例如:main_item.xml、
9 動畫文件(anim文件夾下):所有小寫,採用下劃線命名法,加前綴區分。
//前面爲動畫的類型,後面爲方向
動畫命名例子 |
規範寫法 |
備註 |
fade_in |
淡入 |
|
fade_out |
淡出 |
|
push_down_in |
從下方推入 |
|
push_down_out |
從下方推出 |
|
push_left |
推像左方 |
|
slide_in_from_top |
從頭部滑動進入 |
|
zoom_enter |
變形進入 |
|
slide_in |
滑動進入 |
|
shrink_to_middle |
中間縮小 |
|
10 資源ID(resourcesid):大小寫規範與方法名一致,採用小駝峯命名法。命名規範爲「資源控件的縮寫 名」+「變量名」。注意:頁面控件名稱應該和控件id名保持一致
strings.xml,colors.xml等中的id命名:
命名模式:activity名稱_功能模塊名稱_邏輯名稱/activity名稱_邏輯名稱/common_邏輯名稱
strings.xml中,使用activity名稱註釋,將文件內容區分開來
11 layout中的id命名
命名模式爲:view縮寫_模塊名稱_view的邏輯名稱
view的縮寫詳情以下:
控件 |
縮寫 |
LayoutView |
lv |
RelativeView |
rv |
TextView |
tv |
Button |
btn |
ImageButton |
imgBtn |
ImageView |
mgView 或則 iv |
CheckBox |
chk |
RadioButton |
rdoBtn |
analogClock |
anaClk |
DigtalClock |
dgtClk |
DatePicker |
dtPk |
EditText |
edtTxt |
TimePicker |
tmPk |
toggleButton |
tglBtn |
ProgressBar |
proBar |
SeekBar |
skBar |
AutoCompleteTextView |
autoTxt |
ZoomControls |
zmCtl |
VideoView |
vdoVi |
WdbView |
webVi |
RantingBar |
ratBar |
Tab |
tab |
Spinner |
spn |
Chronometer |
cmt |
ScollView |
sclVi |
TextSwitch |
txtSwt |
ImageSwitch |
imgSwt |
listView |
lVi 或則lv |
ExpandableList |
epdLt |
MapView |
mapVi |