2012-11-20 103 views
3

我正在關注這個tutorial,我可以使它工作得很好,但是當我嘗試更新UI以適應Android 4.2中的新Holo.Light時,應用程序在啓動時崩潰,而且我不知道爲什麼。更新舊的Android項目

我一直在尋找一種方法來更新用戶界面,但我無法得到它的工作。

不知有人能幫助我嗎?告訴我怎麼樣?給我一個你知道會工作的鏈接? 甚至自己動手嗎?

我得到這個錯誤日誌:

11-20 09:50:39.523: I/dalvikvm(1460): threadid=3: reacting to signal 3 
11-20 09:50:39.682: I/dalvikvm(1460): Wrote stack traces to '/data/anr/traces.txt' 
11-20 09:50:39.892: I/dalvikvm(1460): threadid=3: reacting to signal 3 
11-20 09:50:40.003: I/dalvikvm(1460): Wrote stack traces to '/data/anr/traces.txt' 
11-20 09:50:40.102: D/AndroidRuntime(1460): Shutting down VM 
11-20 09:50:40.102: W/dalvikvm(1460): threadid=1: thread exiting with uncaught exception (group=0x409c01f8) 
11-20 09:50:40.132: E/AndroidRuntime(1460): FATAL EXCEPTION: main 
11-20 09:50:40.132: E/AndroidRuntime(1460): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidhive.jsonparsing/com.androidhive.jsonparsing.AndroidJSONParsingActivity}: android.os.NetworkOnMainThreadException 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread.access$600(ActivityThread.java:123) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.os.Handler.dispatchMessage(Handler.java:99) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.os.Looper.loop(Looper.java:137) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread.main(ActivityThread.java:4424) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at java.lang.reflect.Method.invokeNative(Native Method) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at java.lang.reflect.Method.invoke(Method.java:511) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at dalvik.system.NativeStart.main(Native Method) 
11-20 09:50:40.132: E/AndroidRuntime(1460): Caused by: android.os.NetworkOnMainThreadException 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at java.net.InetAddress.lookupHostByName(InetAddress.java:391) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at java.net.InetAddress.getAllByName(InetAddress.java:220) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at com.androidhive.jsonparsing.JSONParser.getJSONFromUrl(JSONParser.java:38) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at com.androidhive.jsonparsing.AndroidJSONParsingActivity.onCreate(AndroidJSONParsingActivity.java:53) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.Activity.performCreate(Activity.java:4465) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920) 
11-20 09:50:40.132: E/AndroidRuntime(1460):  ... 11 more 
11-20 09:50:40.392: I/dalvikvm(1460): threadid=3: reacting to signal 3 
11-20 09:50:40.412: I/dalvikvm(1460): Wrote stack traces to '/data/anr/traces.txt' 
11-20 09:50:40.791: I/dalvikvm(1460): threadid=3: reacting to signal 3 
11-20 09:50:40.962: I/dalvikvm(1460): Wrote stack traces to '/data/anr/traces.txt' 
+1

LogCat中的任何錯誤跟蹤? – fiddler

+0

我們不知道爲什麼,除非你的帖子logcat跟蹤 –

+0

當然,這裏是: http://i.imgur.com/drBOV.png – magnuskahr

回答

0

這個問題有兩個解決方案。

1)不要在主UIThread中使用異步任務編寫網絡調用。

2)在setContentView(R.layout.activity_main)之後將代碼寫入MainActivity文件中;

if (android.os.Build.VERSION.SDK_INT > 9) { 
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); 
    StrictMode.setThreadPolicy(policy); 
} 

和下面的import語句放到你的java文件中。

import android.os.StrictMode; 

並參見下面的鏈接瞭解更多信息。

Twitter connect error

+0

謝謝!你的第二個解決方案工作得很好 – magnuskahr

+0

@MagnusJensen歡迎Magnus。 –

+2

這是一個非常糟糕的主意。所有這一切都是爲了防止報告問題,並且不會改變您在UI線程上進行網絡調用可能導致ANR的事實。跟第一點相比,第二點你會好得多。 –

2

您正在主線程上的網絡電話。這在Android 4.2上是不允許的,而且在早期版本中這是一個非常糟糕的主意,它確實允許這樣做。我已經寫了關於將網絡和其他重要呼叫從主線程移動到http://blog.stylingandroid.com/archives/833的各種機制的博客。

沒有看到您的代碼,我不能開始建議哪種方法適合您使用,但希望我的文章中的信息將幫助您決定正確的方法。