[Android问答] 开发环境问题集锦

采得百花成蜜后,为谁辛苦为谁甜。这篇文章主要讲述[Android问答] 开发环境问题集锦相关的知识,希望能为你提供帮助。

[Android问答] 开发环境问题集锦

文章图片

工欲善其事,必先利其器。
和ios开发相比,android的开发环境的版本比较多,随之而来的问题也多。显然,我们不应该浪费宝贵的时间在解决开发环境带来的问题上,为此本文总结了常见的开发环境问题和解决方法,供大家查询和随时补充。
Debug certificate expiredAndroid SDK生成的用于调试的证书文件debug.keystore有效期是365天,当使用超过一年后控制台就会报这个错误。
Error generating final archive: Debug Certificate expired on 10/09/18 16:30

解决方法是手工删除debug.keystore文件,Windows系统下位于"C:\\Documents and Settings\\username\\.android"目录,Linux和Mac系统下位于"~/.android/"目录。下次启动应用时,Eclipse会自动新建一个debug.keystore文件。最好"Project-> Clean"一下项目以便触发编译器重新编译。
Failed to install apk on device: timeout导致这个问题的确切原因不清楚,可能是由于不正确关闭adb连接。
Failed to install helloworld.apk on device \'emulator-5554\': timeout

解决方法1:更换电脑usb口(不使用前置usb口)或重装手机驱动,将手机关机后再开机。
解决方法2:在Eclipse里选择"Window-> Preferences-> Android-> DDMS-> ADB connection time out",将缺省的5000ms改为更大的值,例如20000ms。
解决方法3:在命令行窗口里依次输入如下命令:
adb kill-server adb start-server

invalid command-line parameter这是由于Eclipse开发环境无法找到所需的可执行文件造成的。
[2011-07-10 07:10:22 - demo] Android Launch! [2011-07-10 07:10:24 - demo] adb is running normally. [2011-07-10 07:10:24 - demo] Performing com.demo.DemoActivity activity launch [2011-07-10 07:10:25 - demo] Automatic Target Mode: launching new emulator with compatible AVD \'xxx\' [2011-07-10 07:10:25 - demo] Launching a new emulator with Virtual Device \'xxx\' [2011-07-10 07:11:06 - Emulator] invalid command-line parameter: Files\\Android\\android-sdk\\tools/emulator-arm.exe.

解决方法是在Eclipse里选择"Window-> Preferences-> Android"选项,检查"SDK Location"的路径是否包含了空格,如果是"c:\\Program Files\\android"这种,改为"c:\\Progra~1\\android",这样命令行就可以正常调用到了。
小提示:在命令行窗口里输入"dir /x"命令就可以列出8.3格式的文件名,看下面的结果:
2012-09-2523:52< DIR> WATCHD~1WatchData 2012-09-0111:01< DIR> Winamp 2012-07-2422:22< DIR> WINDOW~4Windows Live 2012-07-2422:21< DIR> WI3957~1Windows Live SkyDrive

INSTALL_FAILED_INSUFFICIENT_STORAGE安装应用程序时遇到存储容量不足时会报这个错误:
Installation error: INSTALL_FAILED_INSUFFICIENT_STORAGE Please check logcat output for more details. Launch canceled!

如果是在模拟器上运行应用,可以扩大AVD的内存容量。
如果是在真机上运行,可以在AndroidManifest.xml里修改安装偏好,让应用直接安装到SD卡上解决。
< manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example" android:installLocation="preferExternal" > ... < /manifest>

Unable to open sync connection虽然很多人遇到这个问题,但问题的根源并不确切,可能有多种原因造成adb报这个错误:
[2010-10-12 09:36:48 - myapp] Android Launch! [2010-10-12 09:36:48 - myapp] adb is running normally. [2010-10-12 09:36:48 - myapp] Performing com.mycompany.myapp.MyActivity activity launch [2010-10-12 09:36:48 - myapp] Automatic Target Mode: using device \'xxx\' [2010-10-12 09:36:48 - myapp] Uploading myapp.apk onto device \'xxx\' [2010-10-12 09:36:48 - myapp] Failed to upload myapp.apk on device \'xxx\' [2010-10-12 09:36:48 - myapp] java.io.IOException: Unable to open sync connection! [2010-10-12 09:36:48 - myapp] Launch canceled!

解决方法1:拔掉手机连接线再重新连上;
解决方法2:在手机上关闭Debug选项再重新打开,这个选项在手机的"设置-> 应用程序-> 开发-> USB调试"里。
Too many open files这个问题与系统可同时打开文件数量设置有关,但一般不需要修改相关设置,用上一个问题(Unable to open sync connection)的方法即可解决。
第三方Jar包,NoClassDefFoundError升级ADT版本以后容易出现这个问题:本来一切正常的Android项目,升级以后所有的第三方Jar包里的类都提示NoClassDefFoundError了。
原因可能出现在不同版本ADT使用的编译ant脚本的区别,可能的解决方法有两个:
方法1:在Eclipse里右键点击你的Android工程,选择"Properties-> Java Build Path-> Order and Export",在这里把所有第三方Jar包前面的复选框都勾上。
方法2:检查你的第三方Jar包文件是否放在工程目录下的"libs"目录,如果不是,改过来。
Failed to allocate memory: 8一般是AVD的设置有问题,很可能是RAM值设得太高,降低些试试。早期adt版本里有个bug,就是RAM值里必须包含"MB",例如是"512MB"而不是"512",否则提示上述错误信息。
【[Android问答] 开发环境问题集锦】也有人提到过分辨率是原因之一,但我没有实际遇到过,如果只改小RAM没有解决问题,试着把分辨率也调低看看。

    推荐阅读