错误编码 错误说明 举例
40 变量未声明
506 固定的Boolean值 char c=3;
if(c<300){}
525 缩排格式错误
527 无法执行到的语句 if(a > B)
return TRUE;
else
return FALSE;
return FALSE;
529 变量未引用 检查变量未引用的原因
530 使用未初始化的变量
534 忽略函数返回值
539 缩排格式错误
545 对数组变量使用& char arr[100], *p;
p=&arr;
603 指针未初始化 void print_str(const char *p);
…
char *sz;
print_str(sz);
605 指针能力增强 void write_str(char *lpsz);
…
write_str(“string”);
613 可能使用了空指针
616 在switch语句中未使用break;
650 比较数值时,常量的范围超过了 if( ch == 0xFF ) ...
变量范围
713 把有符号型数值赋给了无符号型
数值
715 变量未引用
725 Indentation错误
734 在赋值时发生变量越界 int a, b, c;
…
c=a*b;
737 无符号型变/常量和有变量型
变/常量存在于同一个表达式中。
744 在switch语句中没有default
752 本地声明的函数未被使用
762 函数重复声明
774 Boolean表达式始终返回真/假 char c;
if(c < 300)
3.1. 检查级别设置
Android-Lint所要检查的问题以Issue来描述。
Issue分9类(Category):
Issue以一个文本短语来作为id,对Issue的定制等操作都是基于id的
Android lint以Severity来标识该Issue的危害程度:Fatal/ Error / Warning/
Information/Ignore。对Issue的忽略操作其实也就是降低它的Severity为Ignore。
在Eclipse 中可以在菜单windowàpreferenceàlint error checking中设置规则的检级
级别。
3.2 定制Lint检查的规则
对Android-Lint发现的问题,我们需要进一步的处理:是确实存在的我们自己的设计问题,要解决它;对无关紧要或者是我们特别设计的问题,要在Android-Lint中忽略掉
Android-Lint有默认的检查和报错的规则,但是也可以在Eclipse或者命令行下改变这种规则,从而可以定制Lint检查的规则。
4 常见的提示及其原因和解决
4.1
1) 错误原因:res中作了支持多种语言的strings.xml,但是里面的内容却没有一一对应(或多或少),如上例: 在中文版的strins.xml里有定义sort_letter等字串,在英文版的string.xml里却没有定义。
android 的建议是: If an application has more than onelocale, then all the strings declared in one language should also be translatedin all other languages.
2) 解决办法: 补全缺少翻译的字串
4.2
1) 错误地方:
2) 提示:
"main_landscreen_filtration_packagename" is nottranslated in zh-rCN"
3) 错误原因:
此例实际是上例的补充,当有些字串确实只需要一种语言,而不需要翻译成其它语言的,你也不应该不去理会它,处理方法之一是加上合适的属性translatable="false"。
Android的建议是: If the string should not be translated,you can add the attribute translatable="false" on the <string>element
4) 解决后:
4.3
1) 地方:
2)提示:
Replace "..." with ellipsischaracter (…, …) ?
3)原因:
HTML特殊字符需用编码代替,注意 &#; 这三个符号都不能少。
其它一些常见的特殊字符,“–”需要用“–”;“—”需要用“—”
“½”需要用“½”
4)解决后:
4.4
1) 错误地方:
2) 提示: Should use"sp" instead of "dp" for text sizes
3) 错误原因:
为了适应不同的屏幕分辨率,字体大小的单位应该使用 sp 进行计量
Android的建议: When setting text sizes, you should normallyuse sp, or "scale-independent pixels". This is like the dp unit, butit is also scaled by the user's font size preference
4) 解决后:
4.5
1) 出错地方:
2) 提示: Avoid using "px" as units; use"dp" instead
3) 出错原因:
1.dip: device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。
这里要特别注意dip与屏幕密度有关,而屏幕密度又与具体的硬件有关,硬件设置不正确,有可能导致dip不能正常显示。在屏幕密度为160的显示屏上,1dip=1px,有时候可能你的屏幕分辨率很大如480*800,但是屏幕密度没有正确设置比如说还是160,那么这个时候凡是使用dip的都会显示异常,基本都是显示过小。
dip的换算:
dip(value)=(int) (px(value)/1.5 + 0.5)
2. dp: 很简单,和dip是一样的。
3. px: pixels(像素),不同的设备不同的显示屏显示效果是相同的,这是绝对像素,是多少就永远是多少不会改变。
4. sp: scaled pixels(放大像素). 主要用于字体显示bestfor textsize。
备注: 根据google的推荐,像素统一使用dip,字体统一使用sp
Android的建议: Avoid using"px" as units; use "dp" instead
4) 解决后:
4.6
1) 出错地方:
<stringname="page_num">第1/5页</string>
R.drawable.menu_tab_on
2) 提示:
The resource R.drawable.menu_tab_on appears to be unused
The resourceR.string.page_num appears to be unused
The following unrelated icon fileshave identical contents: bar_selecd.png,local_music_progressbar_indicator.9.png
3) 错误原因
资源里有图片或者字串,在代码里没有用到,应该删掉以节省空间和编译时间
Android建议: Unused resources make applications largerand slow down builds.
4.7
1) 出错地方:
2) 提示:
Missing contentDescription attribute on image
3) 错误原因:
这是ADT 16.0的新特性,在一些没有文本显示的控件里,如imageView和imageButton等,ADT会提示你定义一个android:contentDescription属性,用来描述这个控件的作用,设置View的备注说明。
在界面上不会有效果,自己在程序中控制,可临时放一点字符串数据。
Android建议: Non-textual widgets like ImageViews andImageButtons should use the contentDescription attribute to specify a textualdescription of the widget such that screen readers and other accessibilitytools can adequately describe the user interface.
4) 解决后:
4.8
1) 出错地方:
2) 出错提示:
<uses-permission> tag appears after <application>tag
3) 出错原因:
androidManifest.xml中,uses-permission、uses-sdk等界定应用需要的标签应该置于<application>标签之前,否则有可能会出现一些小的bug(如一些主题得不到正确应用等)。
Andriod建议: The <application> tag should appearafter the elements which declare which version you need, which features youneed, which libraries you need, and so on.
4) 解决后:
4.9
1) 警告地方:
2) 警告提示:
<uses-sdk> tag should specify a target API level
3) 警告原因:
Uses-sdk应该同时具备minSdkVersion和targetSdkVersion属性
Android建议:The manifest should contain a<uses-sdk> element which defines the minimum minimum API Level requiredfor the application to run, as well as the target version (the highest APIlevel you have tested the version for.)
4) 解决后:
4.10
1) 警告地方:
2) 警告提示:
Permission is only granted to system apps
3) 警告原因:
该类权限仅有系统级别的应用才可以使用,其它的一般应用在Manifest.xml里面申明是没有效果的
Android建议: Permissions with the protection levelsignature or signatureOrSystem are only granted to system apps. If an app is aregular non-system app, it will never be able to use these permissions.
4.11
1) 出错地方:
2) 提示:
Should explicitly set android:allowBackup to true or false
3) 错误原因:
adbbackup -apk com.imangi.templerun -f D:\test.ab,该命令不需要解锁 刷ROOT
所以对应用来说是具有一定安全隐患的,
从应用数据的安全角度出发,android建议在application标签内明确加上android:allowBackup的属性,来明确你是否允许用户自行备份数据。只有当android:allowBackup="true"后,用户才可以通过adb backup 和 adb restore命令来对设备上应用的数据进行备份和恢复,备份后,应用的所有数据可以被用户查看。
虽然android默认了该属性为true值,但还是提倡在Manifest上明确指定你是否希望自己的应用数据被用户备份、访问和恢复。
4) 解决后:
4.12
1) 警告地方:
2) 警告提示:
Exported service does not require permission
3) 原因:
为了安全起见,Exportedservice,应该设置用户权限来让相应的应用才可以绑定和使用该服务,如果不设置,就是任何应用都可以随意绑定和使用该服务。当然,如果你的服务确实
仅供自己用,谢绝他人的话,也可以指定exported=false属性
Android建议: Exportedservices (services which either set exported=true or contain an intent-filterand do not specify exported=false) should define a permission that an entitymust have in order to launch the service or bind to it. Without this, any application can use this service.
4) 解决后:
4.13
1) 出错地方:
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="155dp"
android:layout_height="189dp"
android:orientation="vertical" >
<ImageView
…....
/>
<TextView
……
/>
</LinearLayout>
2) 提示:This tag and its childrencan be replaced by one <TextView/> and a compound drawable
3) 出错原因:
当一个Layout里面,只包含简单的ImageView,TextView时,应该换成一个TextView加
图片的方式,这样更有效率
如android建议:ALinearLayout which contains an ImageView and a TextView can be more efficientlyhandled as a compound drawable
4) 解决后:
Xml里
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="155dp"
android:layout_height="189dp" />
<TextView
android:id="@+id/recentAppName"
……
/>
</LinearLayout>
代码里
TextView appName= (TextView) v.findViewById(R.id.recentAppName);
appName.setText(appUnit.getAppName());
Drawable appIcon =appUnit.getAppIcon();
appIcon.setBounds(0,0, 120, 120);
appName.setCompoundDrawables(null,appIcon, null, null);
4.13
1) 出错地方:
2) 错误提示:
Do not hardcode "/sdcard/"; use Environment.getExternalStorageDirectory().getPath()instead
3) 错误原因:
Hardcode问题
andriod建议: Your code should not reference the /sdcardpath directly; instead use Environment.getExternalStorageDirectory().getPath()
4) 解决后:
4.14
1) 警告地方:
2) 警告提示:
Use Integer.valueOf(nValue) instead
3) 原因:
New Integer(): 每次都会创建一个新的对象,即在内存中开辟新的空间
Integer.valueof(): 当传入的整数是-128~127之外时,才会去调用一个new Integer()方法去创建一个新的对象,否则会使用静态类IntegerCache中的cache里的对象。基本上平时的程序中,这个范围的整数是最常用的。所以采用valueof方式,会更有效率和节省内存。Long等其它类型也同理。
Andriod的建议:You shouldnot call the constructor for wrapper classes directly, such as`newInteger(42)`. Instead, call the valueOf factory method,such as Integer.valueOf(42). This will typically use less memory because commonintegers such as 0 and 1 will share a single instance.
4) 解救后:
4.17
1) 警告地方:
2)提示:
Implicitly using the defaultlocale is a common source of bugs: Use toLowerCase(Locale) instead
3) 原因:
使用字串的大小写转换方法时,应该明确地指定语言环境,而不应该简单地调用toLowerCase()了事(系统默认的语言环境)。
一个很明显的例子就是: 土耳其语言里,字母 “i”的大写形式是 ”İ”,而不是” I” .如果系统的默认语言是英语的话,直接调用toLowerCase()自然就会转换出错。
4)解决后:
4.8
1) 错误地方:
2) 提示:
This Handler class should bestatic or leaks might occur (com.tcl.simpletv.myapps.StartActivity.MainHandler)
3) 错误原因:
在Android中,Handler特别是当它作为内部类,且里面有访问到外部类的成员时,此Handler类应该申明为static类型,否则有可能造成泄露。在程序消息队列中排队的消息保持了对目标Handler类的应用。如果Handler是个内部类,那么它也会保持它所在的外部类的引用。为了避免泄露这个外部类,应该将Handler声明为static嵌套类,访问外部类时时,使用对外部类的弱应用。
private HandlermMainHandler;
mMainHandler= new MainHandler(this);
static class MainHandler extends Handler {
WeakReference<StartActivity>mActivity;
publicMainHandler(StartActivity activity) {
mActivity = newWeakReference<StartActivity>(activity);
//TODO Auto-generated constructor stub
}
@Override
public voidhandleMessage(Message msg) {
StartActivitytheActivity = mActivity.get();
switch(msg.what) {
caseGET_APP_LIST:
theActivity.getInstalledAppsData();
break;
default:
break;
}
}
}
4.16
1) 警告地方:
2) 警告提示:
Use newSparseIntArray(...) instead for better performance
3) 原因:
SparseArray是android里为<Interger,Object>这样的Hashmap而专门写的类,目的是提高效率,其核心是折半查找函数(binarySearch)
在Android中,当我们需要定义HashMap<Integer,E>hashmap = new HashMap<Integer,E>
时,可以使用如下的方式来取得更好的性能
SparseArray<E>sparseArray = new SpaseArray<E>()
4) 解决后:
当然,并不是Android Lint发现的所有错误在任何时候都是合理的,你可以根据你的实际情况选择采纳或者忽略。但我强烈建议大家把每个错误里的详细描述都看一下,这是非常好的学习资料,因为这些错误(或者说是建议)可以说是长久以来android开发经验的一个汇总,非常有价值,其价值甚至超过了发现的问题本身。
…………………….