Android錯誤資訊的匯總
犯過的錯給自己提個醒
【錯誤資訊】
[2011-01-19 16:39:10 - ApiDemos] WARNING: Application does not specify an API level requirement!
[2011-01-19 16:39:10 - ApiDemos] Device API version is 8 (Android 2.2)
原因:
不影響正常運行。在AndroidManifest.xml檔案中沒有加API的版本號碼,在 之間加
[2011-01-19 16:55:04 - ApiDemos] Installation error: INSTALL_FAILED_INSUFFICIENT_STORAGE
[2011-01-19 16:55:04 - ApiDemos] Please check logcat output for more details.
[2011-01-19 16:55:05 - ApiDemos] Launch canceled!
該裝置沒有足夠的儲存空間來安裝應用程式,
【錯誤資訊】
[2011-02-18 11:46:53] Failed to push selection: Is a directory
原因:
原先目錄已經有pkg_3.apk的檔案夾,再copy一個pkg_3.apk安裝檔案時出現問題,解決辦法,先刪除掉pkg_3.apk的檔案夾
[2011-03-04 09:25:12 - ActivityMain]: Dx
UNEXPECTED TOP-LEVEL EXCEPTION:
java.lang.IllegalArgumentException: already added: Lorg1/apache/commons/codec/net/RFC1522Codec;
[2011-03-04 09:25:12 - ActivityMain]: Dx at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123)
[2011-03-04 09:25:12 - ActivityMain]: Dx at com.android.dx.dex.file.DexFile.add(DexFile.java:143)
.....
[2011-03-04 09:25:12 - ActivityMain]: Dx1 error; aborting
[2011-03-04 09:25:12 - ActivityMain] Conversion to Dalvik format failed with error 1
原因:
【錯誤資訊】
啟動Eclipse時出現:
this android sdk requires android developer toolkit version 10.0.0 or above.
current version is 8.0.1.v201012062107-82219.
please update adt to the latest version
原因:
Eclipse的Android開發外掛程式版本過低,應該下載ADT-10.0.0,並且
1. 啟動 Eclipse, 然後進入 Help > Install New Software.
2. 在 Available Software 對話方塊裡,點擊 Add....
【錯誤資訊】
[2011-03-09 15:21:34 - Info] Failed to install Info.apk on device '?': Unable to open sync connection!
[2011-03-09 15:21:34 - Info] java.io.IOException: Unable to open sync connection!
[2011-03-09 15:21:34 - Info] Launch canceled!
原因:
關閉模擬器和eclipse,執行adb kill-server命令,然後重試一下
【錯誤資訊】
調用Webservice時出現
java.net.SocketException: Permission denied (maybe missing INTERNET permission)
原因:
需要訪問到網路,所以,在AndroidManifest.xml中,需要進行如下配置:
【錯誤資訊】
org.xmlpull.v1.XmlPullParserException: expected: START_TAG {http://schemas.xmlsoap.org/soap/envelope/}Envelope (position:START_TAG <{http://schemas.xmlsoap.org/wsdl/}wsdl:definitions targetNamespace='http://bo.webservice.nqbx.nq.com'>@2:603 injava.io.InputStreamReader@44a3a7b0)
原因有可能是以下2個之一:
1)Webservice伺服器的Soap版本為1.0,所以用戶端指定
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);
VER11改為VER10
2)String serviceUrl = http://200.200.200.11:10000/nqbx/service/InqBxWebService?wsdl;
Url指的是你的webservice的地址.一般都是以***.wsdl或者***.?wsdl結束的...但是.需要注意的是..要去掉後面的.wsdl或者.?wsdl
【錯誤資訊】
在新的線程中 public class HttpThread extends Thread {...}
增加一個彈出表單:
new AlertDialog.Builder(this).setTitle(資料載入失敗).setMessage(請檢查網路連接情況) .setPositiveButton(OK, new DialogInterface.OnClickListener(){ public void onClick(DialogInterface dialoginterface, int i) { } }).show();
原因及解決辦法:
//不能線上程中操作UI介面
java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
修改後:
new AlertDialog.Builder(com.nantsing.infoquery.chuanbo_detail.this).setTitle(資料載入失敗).setMessage(請檢查網路連接情況) .setPositiveButton(OK, new DialogInterface.OnClickListener(){ public void onClick(DialogInterface dialoginterface, int i) { }
【錯誤資訊】
The constructor AlertDialog.Builder(chuanbo_detail.HttpThread) is undefined
原因及解決辦法:
在UI主線程之外是無法對UI組件進行控制的。因為你必須在新線程任務完成之後利用各種方法先UI主線程發送訊息通知任務完成從而來顯示各種提示訊息。
線程間通訊方法有多種,常用的是用handler來傳遞訊息。
如下:
線程中構造訊息:
//構造訊息Message message = handle.obtainMessage();Bundle b = new Bundle();b.putString(tag, 1);message.setData(b);handle.sendMessage(message);
另外自訂訊息:
/** * 捕獲訊息佇列 fubin.pan 2011-04-02 */Handler handler = new Handler() {public void handleMessage(Message m) {if (!m.getData().getString(tag).equals(1)){ ...}else{new AlertDialog.Builder(chuanbo_detail.this).setTitle(資料載入失敗).setMessage(請檢查網路連接情況!) .setPositiveButton(OK, new DialogInterface.OnClickListener(){ public void onClick(DialogInterface dialoginterface, int i) { } }).show();}}};
【錯誤資訊】
android低版本工程(如1.5)放到高版本環境中(如2.2)可能會上述錯誤,解決方案如下:
1。 如果不修改android sdk版本,則使用project clean 命令作用於某工程即可。
(該處理方式只是在高版本中相容了低版本工程,未真正意義上的升級)
2。 如果修改android sdk版本,則需要以下幾個步驟:
1)修改SDK
選擇工程,build path --> configure build path ---> library 刪除引用的低版本SDK,
然後add External JARs,選擇高版本SDK,OK,儲存
2)修改classpath檔案
該檔案可能存在該項: 把她修改成
3) 修改AndroidManifest.xml
在AndroidManifest.xml檔案中,application標籤後添加
4) 修改default.properties(很重要)
該檔案最後一行(前面沒用#的)target=android-3 該成target=android-8,儲存。
再看看你的工程和建立的android 2.2的工程結構就一樣了。
【錯誤資訊】
線上程debug(運行沒有問題)時調用Webservice時出現:
'JDI thread evaluations' has encountered a problem
Exception processing async thread queue
Exception processing async thread queue
JDI thread evaluations
原因及解決辦法:
與運行無關的錯誤,關掉'expressions'視圖就可以了
【錯誤資訊】
開啟開源項目JavaEye Android client時出錯
http://javaeye-android-client.googlecode.com/svn/trunk/
這是 JavaEye 網站基於 Android 平台的用戶端軟體,可用以閱讀動靜、文章、閑談, 收躲, RSS 等功用。
[2011-04-19 10:55:11 - JavaEye Android Client] Project has no default.properties file! Edit the project properties to set one.
原因及解決辦法:
遇到這種情況,可以建立一個default.properties檔案,如果建立之後還是有錯誤,那麼delete這個project,重新import。
編輯default.properties 之後,一般會自動建立 gen 目錄, 如果沒有,也可嘗試手工建立。
?Adroid Adapter ADB Interface 嚴重錯誤
今天在配置完Eclipse和Android SDK開發環境之後,想用華為C8500手機通過USB串連電腦,並在手機上去調試,但莫名其妙出現Adroid Adapter ADB Interface 安裝嚴重錯誤,在豌豆莢手機精靈安裝驅動的時候,也出現這個錯誤,後面也莫名奇妙的多裝幾次就好了,還沒找到什麼原因。
【錯誤資訊】
用手機調試運行出現:
ActivityManager: Warning: Activity not started, its current task has been brought to the front
原因及解決辦法:
該手機已經啟動了相同名字的應用,關閉之後再試!
【錯誤資訊】
最近(2012-04-05)在開啟SDK Manager.exe,更新SDK時,會出現如下錯誤:
Failed to fetch URL https://dl-ssl.google.com/android/repository/repository.xml,
reason: Connection timed out: connect
原因及解決辦法:
dl-ssl.google.com在大陸封掉了
解決方案就是修改C:WindowsSystem32driversetchosts檔案。添加一行:
74.125.237.1 dl-ssl.google.com
儲存,重新啟動SDK Manager.exe
【錯誤資訊】
[2012-04-08 17:42:24 - JavaEye Android Client] ------------------------------
[2012-04-08 17:42:24 - JavaEye Android Client] Android Launch!
[2012-04-08 17:42:24 - JavaEye Android Client] The connection to adb is down, and a severe error has occured.
[2012-04-08 17:42:24 - JavaEye Android Client] You must restart adb and Eclipse.
[2012-04-08 17:42:24 - JavaEye Android Client] Please ensure that adb is correctly located at 'C:androidandroid-sdk-windowsplatform-toolsadb.exe' and can be executed.
原因及解決辦法:
查看工作管理員,關閉所有adb.exe
重啟eclipse即可
【錯誤資訊】
更新SDK時錯誤資訊:
Site Authentication
Please login to the following ......
原因及解決辦法:
Cancel跳過提示
【錯誤資訊】
開啟Eclipse 提示安裝ADT 17
原因及解決辦法:
最新的Android SDK只能安裝ADT 17.0.0
可用的:http://download.csdn.net/detail/merrido/4169460,
這裡可不能用常規方法安裝這個 ADT 17.0.0.zip 檔案, 首先得解壓這個檔案,將裡面的檔案夾覆蓋掉Eclipse安裝目錄下的檔案夾。
然後再用Help-> install new software->Add -> Name: ADT Archive:選擇ADT 17.0.0.zip
【錯誤資訊】
安裝ADT 17.0.0時,提示:
Your original request has been modified.
Android DDMS is already installed, so an update will be performed instead.
Android Development Tools is already installed, so an update will be performed instead.
Android Hierarchy Viewer is already installed, so an update will be performed instead.
Android Traceview is already installed, so an update will be performed instead.
Cannot complete the install because one or more required items could not be found.
Software being installed: Android Development Tools 17.0.0.v201203161636-291853 (com.android.ide.eclipse.adt.feature.group 17.0.0.v201203161636-291853)
Missing requirement: Android Development Tools 17.0.0.v201203161636-291853 (com.android.ide.eclipse.adt.feature.group 17.0.0.v201203161636-291853) requires 'org.eclipse.core.runtime 3.6.0' but it could not be found
原因及解決辦法:
【錯誤資訊】
Updates ADT 17.0.0時提示:
Cannot complete the install because one or more required items could not be found.
Software being installed: Android Development Tools 17.0.0.v201203161636-291853 (com.android.ide.eclipse.adt.feature.group 17.0.0.v201203161636-291853)
Missing requirement: Android Development Tools 17.0.0.v201203161636-291853 (com.android.ide.eclipse.adt.feature.group 17.0.0.v201203161636-291853) requires 'org.eclipse.core.runtime 3.6.0' but it could not be found
原因及解決辦法:
requires 'org.eclipse.core.runtime 3.6.0' but it could not be found
requires 'org.eclipse.ui 3.6.0' but it could not be found
eclipse需要升級到3.6.0,我的版本是3.5.2
【錯誤資訊】
[2012-04-09 17:14:49 - Info] ------------------------------
[2012-04-09 17:14:49 - Info] Android Launch!
[2012-04-09 17:14:49 - Info] Connection with adb was interrupted.
[2012-04-09 17:14:49 - Info] 0 attempts have been made to reconnect.
[2012-04-09 17:14:49 - Info] You may want to manually restart adb from the Devices view.
原因及解決辦法:
重新啟動eclipse
【錯誤資訊】
[2012-04-10 09:45:49 - adb] ADB server didn't ACK
[2012-04-10 09:45:49 - adb] * failed to start daemon *
原因及解決辦法:
查看工作管理員,關閉所有adb.exe
重啟eclipse
【錯誤資訊】
[2012-04-10 09:53:50 - ApiDemos] ------------------------------
[2012-04-10 09:53:50 - ApiDemos] Android Launch!
[2012-04-10 09:53:50 - ApiDemos] The connection to adb is down, and a severe error has occured.
[2012-04-10 09:53:50 - ApiDemos] You must restart adb and Eclipse.
[2012-04-10 09:53:50 - ApiDemos] Please ensure that adb is correctly located at 'C:androidandroid-sdk-windowsplatform-toolsadb.exe' and can be executed.
原因及解決辦法:
重啟eclipse
【錯誤資訊】
安裝android sdk時:
-= warning! =- A folder failed to be renamed or moved. On Windows this typically means that a program Is using that Folder (for example Windows Explorer or your anti-virus software.) Please momentarily deactivate your anti-virus software. Please also close any running programs that may be accessing the directory 'C:androidandroid-sdk-windows/android-sdk-windows/too!s'. When ready, press YES to try again.
原因及解決辦法:
1, 複製 tools目錄
為一個新的目錄 tools-copy ,此時在android-sdk-windows 目錄下有兩個目錄 tools 和 tools-copy
2, 在tools-copy目錄以管理員身份運行 android.bat ,這樣就可以正常 update all 了
3.重新運行SDK Manager.exe.問題解決!
【錯誤資訊】
“正在啟動JavaEyeApiAccessor“遇到問題。
不能串連至VM
原因及解決辦法:
串連不到手機虛擬機器
重啟拔插手機連接線
【錯誤資訊】
調試的時候:
[2012-04-13 17:46:27 - IpsosAutoAndroid] Failed to install IpsosAutoAndroid.apk on device '?': timeout
[2012-04-13 17:46:27 - IpsosAutoAndroid] Launch canceled!
原因及解決辦法:
串連真機調試的時候如果串連太久沒響應就會出現timeout
1.在window-》prensent....-》android-》設定ddms的timeout時間。這種是就最有效、最簡潔的。
2.delete android裡面的 apk,保證速度。不過試過一次後,真機好像變“聰明了”,也出現timeout。
3.Cleaning the project (Project->Clean),不行就重啟eclipse或者android,很鬱悶的是,重啟後運行第一次可以。第二次就開始變慢了,也就是出現timeout
4.關閉eclipse ,然後再重啟,就ok
【錯誤資訊】
調用org.ksoap2.*訪問webservice時
04-13 10:09:49.565: E/dalvikvm(354): Could not find class 'org.ksoap2.serialization.SoapObject', referenced from method......
04-13 10:09:49.585: E/dalvikvm(354): Could not find class 'org.ksoap2.transport.HttpTransportSE', referenced from method......
【錯誤資訊】
Unable to open stack trace file '/data/anr/traces.txt': Permission denied
原因及解決辦法:
Unable to open stack trace file '/data/anr/traces.txt': Permission 多見於這個Activity你沒有在AndroidManifest.xml中註冊,就會報這樣的錯誤。
【錯誤資訊】
source not found
找不到源
原因及解決辦法:
android目錄下沒有對應的sources檔案
如,不知道為什麼,最新的SDK更新API 14/15中有Sources for Android SDK,而之前的版本的源碼就不更新,氣憤!
下載對應的SDK Sources後,放到android-sdk-windowssources 目錄下就OK了!
【錯誤資訊】
Android使用KSOAP2調用WebService時:
java.lang.NoClassDefFoundError: org.ksoap2.serialization.SoapObject
原因及解決辦法:
雖然標明上 Java Build Path->Libraries中已經引用了ksoap2-android 包,但是需要order and export中也把該包勾選上
【錯誤資訊】
error: Error: No resource found that matches the given name (at 'layout_toLeftOf' with value'@id/top_send_btn').
header_questionitemlist.xml /IpsosAutoAndroid/res/layout 第 27 行 Android AAPT Problem
原因及解決辦法:
【錯誤資訊】
無法解析匯入 com.renren.api.connect.android.R
原因及解決辦法:
匯入android源碼有錯,R.java檔案不能自動產生解決方案
【錯誤資訊】
Eclipse中的DDMS無法開啟data檔案夾下的內容,也不能往裡面寫東西
原因及解決辦法:
通過軟體擷取ROOT許可權
【錯誤資訊】
Fri May 04 16:27:46 CST 2012
Internal error logged from JDI Debug:
org.eclipse.jdi.TimeoutException: 等待包 8 時發生逾時。
at org.eclipse.jdi.internal.connect.PacketReceiveManager.getReply(PacketReceiveManager.java:171)
at org.eclipse.jdi.internal.connect.PacketReceiveManager.getReply(PacketReceiveManager.java:180)
......
原因及解決辦法:
重新啟動eclipse,不行的話重啟機器
【錯誤資訊】
java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
原因及解決辦法:
如下是有問題的代碼:
Thread t = new Thread() {@Overridepublic void run() {super.run();try {QuestionItemlist = quesHandler.getData();if (QuestionItemlist.size() == 0) {Toast.makeText(questionitemlist2.this,問卷題目為空白,Toast.LENGTH_LONG).show();} else {Toast.makeText(questionitemlist2.this,問卷題目已經擷取,Toast.LENGTH_LONG).show();}} catch (Exception e) {e.printStackTrace();}}};t.start();【錯誤資訊】
java.lang.IllegalArgumentException: The key must be an application-specific resource id.
原因及解決辦法:
mRadioButton.setTag(1,sQuestionItem.get(i).getToNext());//設定監聽 ToNext:下一題目mRadioButton.setTag(2,sQuestionItem.get(i).getToEnd());//設定監聽 ToEnd:是否終止 拋出IllegalArgumentException的原因就在於key不唯一,正確代碼如下:
mRadioButton.setTag(R.id.tag_tonext,sQuestionItem.get(i).getToNext());//設定監聽 ToNext:下一題目mRadioButton.setTag(R.id.tag_toend,sQuestionItem.get(i).getToEnd());//設定監聽 ToEnd:是否終止
【錯誤資訊】
點擊Debug 運行 結果模擬器總是會彈出Waiting for Debugger 然後程式又可以正常運行
如果你想調試的時候去掉 Waiting for Debugger 提示
原因及解決辦法:
重啟啟動機器就OK