Android研发规范
微博:@杨光福IT讲师 整理
转自:http://blog.csdn.net/wwj_748/article/details/42347283
1、Android编码规范
包命名规范
包(packages):采用反域名命名规则,全部使用小写字母。一级包名为com,二级包名为xxx(可以是公司域名或者个人命名),三级包名根据应用进行命名,四级包名为模块名或层级名。
包名 |
说明 |
com.xxx.应用名称缩写.activities |
页面用到的Activity类(activities层级用户界面) |
com.xxx.应用名称缩写.fragment |
页面用到的Fragment类 |
com.xxx.应用名称缩写.base |
页面中每个Activity类共享的可以写成一个BaseActivity类(基础共享的类) |
com.xxx.应用名称缩写.adapter |
页面用到的Adapter类(适配器的类) |
com.xxx.应用名称缩写.utils |
此包中包含:公共工具方法类(包含日期、网络、存储、日志等工具类) |
com.xxx.应用名称缩写.bean (model/domain均可,个人喜好) |
实体类 |
com.xxx.应用名称缩写.db |
数据库操作 |
com.xxx.应用名称缩写.view(或者.ui) |
自定义的View类等 |
com.xxx.应用名称缩写.service |
Service服务 |
com.xxx.应用名称缩写.broadcast |
Broadcast服务 |
类命名规范
类(classes):名词,采用大驼峰命名法,尽量避免缩写,除非该缩写是众所周知的,比如HTML,URL,如果类名称包含单词缩写,则单词缩写的每个字母均应大写。
类 |
描述 |
例如 |
Application类 |
Application为后缀标识 |
XXXApplication |
Activity类 |
Activity为后缀标识 |
闪屏页面类 SplashActivity |
解析类 |
Handler为后缀标识 |
|
公共方法类 |
Utils或Manager为后缀标识 |
线程池管理类:ThreadPoolManager 日志工具类:LogUtils |
数据库类 |
以DBHelper后缀标识 |
MySQLiteDBHelper |
Service类 |
以Service为后缀标识 |
播放服务:PlayService |
BroadcastReceiver类 |
以Broadcast为后缀标识 |
时间通知: TimeBroadcast |
ContentProvider类 |
以Provider为后缀标识 |
单词内容提供者:DictProvider |
直接写的共享基础类 |
以Base为前缀 |
BaseActivity, BaseFragment |
变量命名规范
变量(variables)采用小驼峰命名法。类中控件名称必须与xml布局id保持一致。
公开的常量:定义为静态final,名称全部大写。eg: public staticfinal String ACTION_MAIN=”android.intent.action.MAIN”;
静态变量:名称以s开头 eg:private static long sInstanceCount = 0;
非静态的私有变量、protected的变量:以m开头,eg:private Intent mItent;
接口命名规范
接口(interface):命名规则与类一样采用大驼峰命名法,多以able或ible结尾,eg:interface Runable; interface Accessible;
方法命名规范
方法(methods):动词或动名词,采用小驼峰命名法,eg:onCreate(),run();
方法 |
说明 |
initXX() |
初始化相关方法,使用init为前缀标识,如初始化布局initView() |
isXX() |
checkXX()方法返回值为boolean型的请使用is或check为前缀标识 |
getXX() |
返回某个值的方法,使用get为前缀标识 |
processXX() |
对数据进行处理的方法,尽量使用process为前缀标识 |
displayXX() |
弹出提示框和提示信息,使用display为前缀标识 |
saveXX() |
与保存数据相关的,使用save为前缀标识 |
resetXX() |
对数据重组的,使用reset前缀标识 |
clearXX() |
清除数据相关的 |
removeXX() |
清除数据相关的 |
drawXXX() |
绘制数据或效果相关的,使用draw前缀标识 |
布局文件命名规范
全部小写,采用下划线命名法
1).contentview命名, Activity默认布局,以去掉后缀的Activity类进行命名。不加后缀:
功能模块.xml
eg:main.xml、more.xml、settings.xml
或者:activity_功能模块.xml
eg:activity_main.xml、activity_more.xml
2).Dialog命名:dialog_描述.xml
eg:dlg_hint.xml
3).PopupWindow命名:ppw_描述.xml
eg:ppw_info.xml
4). 列表项命名listitem_描述.xml
eg:listitem_city.xml
5).包含项:include_模块.xml
eg:include_head.xml、include_bottom.xml
6).adapter的子布局:功能模块_item.xml
eg:main_item.xml、
资源id命名规范
命名模式为:view缩写_模块名称_view的逻辑名称
view的缩写详情如下:
控件 |
缩写 |
LayoutView |
lv |
RelativeView |
rv |
TextView |
tv |
Button |
btn |
ImageButton |
imgBtn |
ImageView |
iv |
CheckBox |
cb |
RadioButton |
rb |
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 |
动画文件命名
动画文件(anim文件夹下):全部小写,采用下划线命名法,加前缀区分。
//前面为动画的类型,后面为方向
动画命名例子 |
规范写法 |
备注 |
fade_in |
淡入 |
|
fade_out |
淡出 |
|
push_down_in |
从下方推入 |
|
push_down_out |
从下方推出 |
|
push_left |
推像左方 |
|
slide_in_from_top |
从头部滑动进入 |
|
zoom_enter |
变形进入 |
|
slide_in |
滑动进入 |
|
shrink_to_middle |
中间缩小 |
|
图片资源文件命名
命名 |
说明 |
bg_xxx |
这种图片一般那些比较大的图片,比如作为某个Activity的背景等 |
btn_xxx |
按钮,一般用于按钮,而且这种按钮没有其他状态 |
ic_xxx |
图标,一般用于单个图标,比如启动图片ic_launcher |
bg_描述_状态1[_状态2] |
用于控件上的不同状态 |
btn_描述_状态1[_状态2] |
用于按钮上的不同状态 |
chx_描述_状态1[_状态2] |
选择框,一般有2态和4态 |
|
|
一些常见的单词缩写
名称 |
缩写 |
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) |
相关推荐
Android 编码规范指南 Android 应用程序中的编码规范非常重要,它直接影响到应用程序的可读性、可维护性和可扩展性。下面是 Android 编码规范指南的详细解释和说明: 文件命名 * 源文件名称以其最顶层的类名来...
分享一篇Android 编码规范,适用于入门小白,如何敲出简单高效有条理的代码,提高易读性,避免因代码不规范导致的返工以及影响团队协作的效率
Java及Android编码规范,开发者必备
【Android编码规范指南】 在Android应用开发中,遵循一套统一的编码规范是非常重要的,它能够提高代码的可读性、可维护性和团队协作效率。这篇文档主要基于Google的Java编程风格,提供了Android编码的一些基本准则...
1. Android编码规范的参考与目的 文档中明确指出,这份Android编码规范参考了Google Java编程风格规范和Google官方Android编码风格规范。这些规范的目的在于形成一个统一的编程风格,以便于开发者之间的交流和代码的...
自己写的一些关于编码的规范,感兴趣的可以看看。
《Android编码规范详解》 Android编码规范是一套旨在约束开发者编码习惯、提升代码质量和可读性的准则,旨在消除编码过程中的不良习惯,提高团队协作效率。本文将详细解析这一规范,涵盖命名基础、注释规范、代码...
总的来说,这份Android编码规范旨在提升代码质量,促进团队合作,通过规定文件命名、编码格式、结构、命名约定和编程实践,使代码更易于理解和维护。遵循这些规范,可以有效降低项目维护难度,提高开发效率,同时也...
### Android编码规范详解 #### 一、编码规范的重要性与作用 在软件开发过程中,编码规范扮演着至关重要的角色。良好的编码规范不仅能够提高代码的可读性和可维护性,还能促进团队之间的协作效率,减少后期维护成本...
### Android编码规范(老版)知识点详解 #### 一、引言 在软件开发领域,尤其是在Android应用开发中,遵循一套统一的编码规范至关重要。本文档详细介绍了Android编码规范的老版内容,虽然其中某些部分已经过时(尤其...
Android编码规范是为了保证Android应用的开发质量,提高团队协作效率,降低维护成本。下面将详细解释Android编码规范中的几个关键点。 首先,关于包命名,遵循的原则是使用全小写字母的ASCII顶级域名作为前缀,如`...
Java-Android编码规范是Android应用开发中的一个重要组成部分,它旨在提高代码的可读性、可维护性和团队协作效率。以下是对该规范的详细解读: 1. **范围** 编码规范涵盖了Java语言在Android平台上的应用,包括但...