天天看點

Android開發錯誤彙總 .

轉自:http://blog.csdn.net/sheshou2/article/details/6152988

大家都在為項目開發成功而喜悅,但可不知成功的路上是會經常出錯的,下面是我碰到的一些錯誤集合!

【錯誤資訊】

[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的版本号,在<manifest> </manifest> 之間加<uses-sdk android:minSdkVersion="3"></uses-sdk>

[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

Android開發錯誤彙總 .

原因:

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中,需要進行如下配置:

<uses-permission android:name="android.permission.INTERNET" />

【錯誤資訊】

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 in[email protected])

原因有可能是以下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 {...}

增加一個彈出窗體:

[java] view plain copy print ?

  1. new AlertDialog.Builder(this).setTitle("資料加載失敗").setMessage("請檢查網絡連接配接情況")           .setPositiveButton("OK", new DialogInterface.OnClickListener(){            public void onClick(DialogInterface dialoginterface, int i)            {            }            }).show();  

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()

修改後:

[java] view plain copy print ?

  1. new AlertDialog.Builder(com.nantsing.infoquery.chuanbo_detail.this).setTitle("資料加載失敗").setMessage("請檢查網絡連接配接情況")           .setPositiveButton("OK", new DialogInterface.OnClickListener(){            public void onClick(DialogInterface dialoginterface, int i)            {            }  

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來傳遞消息。

如下:

線程中構造消息:

[java] view plain copy print ?

  1. //構造消息Message message = handle.obtainMessage();Bundle b = new Bundle();b.putString("tag", "1");message.setData(b);handle.sendMessage(message);  

//構造消息Message message = handle.obtainMessage();Bundle b = new Bundle();b.putString("tag", "1");message.setData(b);handle.sendMessage(message);

另外自定義消息:

[c-sharp] view plain copy print ?

  1. 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();}}};  

/** * 捕獲消息隊列 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檔案

             該檔案可能存在該項: <classpathentry kind="lib"   path ="你所指定的高版本的位址"

             把她修改成<classpathentry kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK" />

        3) 修改AndroidManifest.xml

             在AndroidManifest.xml檔案中,application标簽後添加<uses-sdk android:minSdkVersion="3"></uses-sdk>

        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

Android開發錯誤彙總 .

Exception processing async thread queue

JDI thread evaluations

Android開發錯誤彙總 .

原因及解決辦法:

與運作無關的錯誤,關掉'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時,會出現如下錯誤:

Android開發錯誤彙總 .

Failed to fetch URL https://dl-ssl.google.com/android/repository/repository.xml,

reason: Connection timed out: connect

原因及解決辦法:

dl-ssl.google.com在大陸封掉了

解決方法就是修改C:\Windows\System32\drivers\etc\hosts檔案。添加一行:

[html] view plain copy print ?

  1. 74.125.237.1       dl-ssl.google.com  
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:\android\android-sdk-windows\platform-tools\adb.exe' and can be executed.

原因及解決辦法:

檢視任務管理器,關閉所有adb.exe

重新開機eclipse即可

【錯誤資訊】

更新SDK時錯誤資訊:

Site Authentication

Please login to the following ......

Android開發錯誤彙總 .

原因及解決辦法:

Cancel跳過提示

【錯誤資訊】

打開Eclipse 提示安裝ADT 17

Android開發錯誤彙總 .

原因及解決辦法:

最新的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

原因及解決辦法:

requires 'org.eclipse.core.runtime 3.6.0' but it could not be found

eclipse需要更新到3.6.0,我的版本是3.5.2

【錯誤資訊】

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:\android\android-sdk-windows\platform-tools\adb.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:\android\android-sdk-windows/android-sdk-windows/too!s'. When ready, press YES to try again.

Android開發錯誤彙總 .

原因及解決辦法:

1, 複制 tools目錄

為一個新的目錄 tools-copy ,此時在android-sdk-windows 目錄下有兩個目錄 tools 和 tools-copy

2, 在tools-copy目錄以管理者身份運作 android.bat ,這樣就可以正常 update all 了

3.重新運作SDK Manager.exe.問題解決!

【錯誤資訊】

“正在啟動JavaEyeApiAccessor“遇到問題。

不能連接配接至VM

Android開發錯誤彙總 .

原因及解決辦法:

連接配接不到手機虛拟機

重新開機拔插手機連接配接線

【錯誤資訊】

調試的時候:

 [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檔案

Android開發錯誤彙總 .

如下圖,不知道為什麼,最新的SDK更新API 14/15中有Sources for Android SDK,而之前的版本的源碼就不更新,氣憤!

Android開發錯誤彙總 .

下載下傳對應的SDK Sources後,放到\android-sdk-windows\sources 目錄下就OK了!

Android開發錯誤彙總 .

【錯誤資訊】

Android使用KSOAP2調用WebService時:

 java.lang.NoClassDefFoundError: org.ksoap2.serialization.SoapObject

原因及解決辦法:

雖然标明上 Java Build Path->Libraries中已經引用了ksoap2-android 包,但是需要order and export中也把該包勾選上

Android開發錯誤彙總 .

【錯誤資訊】

Android開發錯誤彙總 .

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()

原因及解決辦法:

如下是有問題的代碼: 

[java] view plain copy print ?

  1. Thread t = new Thread() {  
  2.     @Override  
  3.     public void run() {  
  4.         super.run();  
  5.         try {  
  6.             QuestionItemlist = quesHandler.getData();  
  7.             if (QuestionItemlist.size() == 0) {  
  8.                 Toast.makeText(questionitemlist2.this,"問卷題目為空",Toast.LENGTH_LONG).show();  
  9.             } else {  
  10.                 Toast.makeText(questionitemlist2.this,"問卷題目已經擷取",Toast.LENGTH_LONG).show();  
  11.             }  
  12.         } catch (Exception e) {  
  13.             e.printStackTrace();  
  14.         }  
  15.     }  
  16. };  
  17. t.start();  
Thread t = new Thread() {
			@Override
			public 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.

原因及解決辦法:

[java] view plain copy print ?

  1. mRadioButton.setTag(1,sQuestionItem.get(i).getToNext());//設定監聽  ToNext:下一題目   
  2. mRadioButton.setTag(2,sQuestionItem.get(i).getToEnd());//設定監聽  ToEnd:是否終止  
mRadioButton.setTag(1,sQuestionItem.get(i).getToNext());//設定監聽  ToNext:下一題目
mRadioButton.setTag(2,sQuestionItem.get(i).getToEnd());//設定監聽  ToEnd:是否終止
           

抛出IllegalArgumentException的原因就在于key不唯一,正确代碼如下:

[java] view plain copy print ?

  1. mRadioButton.setTag(R.id.tag_tonext,sQuestionItem.get(i).getToNext());//設定監聽  ToNext:下一題目   
  2. mRadioButton.setTag(R.id.tag_toend,sQuestionItem.get(i).getToEnd());//設定監聽  ToEnd:是否終止  
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

【錯誤資訊】

拔掉連接配接線,運作程式還出現如下問題:

android Debuger 出現:"Waiting for Debugger - Application XXX is waiting for the debugger to Attach"

然後關閉

原因及解決辦法:

重新開機機器或者重新開機下adb

【錯誤資訊】

AndroidManifest.xml配置中加入android:installLocation="auto"出現錯誤:

error: No resource identifier found for attribute 'installLocation' in package 'android'

Android開發錯誤彙總 .

原因及解決辦法:

開發包需要Android2.2以上

Change the build target by editing the project properties (right-click on the project in Eclipse), and choose a target with at least API Level 8

繼續閱讀