-1

I'm new to Android development. Here is my code:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.util.ArrayList;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.app.ListActivity;
import android.os.Bundle;
import android.widget.ArrayAdapter;

public class MainActivity extends ListActivity {


/** Called when the activity is first created. */

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    setListAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,     this.fetchTwitterPublicTimeline()));
  }

  public ArrayList<String> fetchTwitterPublicTimeline() {
      ArrayList<String> listItems = new ArrayList<String>();

      try {
          URL twitter = new URL("http://twitter.com/statuses/public_timeline.json");
          URLConnection tc = twitter.openConnection();
          BufferedReader in = new BufferedReader(new InputStreamReader(tc.getInputStream()));
          String line;

          while ((line = in.readLine()) != null) {
              JSONArray ja = new JSONArray(line);
              for (int i = 0; i < ja.length(); i++) {
                  JSONObject jo = (JSONObject) ja.get(i);
                  listItems.add(jo.getString("text"));
              }
          }
      } catch (MalformedURLException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      } catch (IOException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      } catch (JSONException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      }

      return listItems;

  } 


}

And here is my acitivity_main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" >
    <ListView android:id="@android:id/list"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
</LinearLayout>

The logcat is below (or at this link):

03-21 09:16:15.530: E/AndroidRuntime(31912):    ... 11 more
03-21 09:16:33.590: E/AndroidRuntime(31991): FATAL EXCEPTION: main
03-21 09:16:33.590: E/AndroidRuntime(31991): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.simplebrowser/com.example.simplebrowser.MainActivity}: android.os.NetworkOnMainThreadException
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread.access$600(ActivityThread.java:141)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.os.Looper.loop(Looper.java:137)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread.main(ActivityThread.java:5041)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at java.lang.reflect.Method.invokeNative(Native Method)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at java.lang.reflect.Method.invoke(Method.java:511)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at dalvik.system.NativeStart.main(Native Method)
03-21 09:16:33.590: E/AndroidRuntime(31991): Caused by: android.os.NetworkOnMainThreadException
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at java.net.InetAddress.getAllByName(InetAddress.java:214)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:70)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:316)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpEngine.connect(HttpEngine.java:311)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:290)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:240)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:282)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:177)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at com.example.simplebrowser.MainActivity.fetchTwitterPublicTimeline(MainActivity.java:38)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at com.example.simplebrowser.MainActivity.onCreate(MainActivity.java:29)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.Activity.performCreate(Activity.java:5104)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
03-21 09:16:33.590: E/AndroidRuntime(31991):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
03-21 09:16:33.590: E/AndroidRuntime(31991):    ... 11 more

I've followed a tutorial for this and I can't seem to get it to work.

Mxyk
  • 10,678
  • 16
  • 57
  • 76
  • look at [networkonmainthreadexception](http://stackoverflow.com/questions/6343166/android-os-networkonmainthreadexception). – Simon Dorociak Mar 20 '13 at 22:31

3 Answers3

0

You have to do network tasks on AsyncTask to avoid blocking the UI thread.

Unable to start activity ComponentInfo{com.example.simplebrowser/com.example.simplebrowser.MainActivity}: android.os.NetworkOnMainThreadException

gpasci
  • 1,420
  • 11
  • 16
0

You cannot call fetchTwitterPublicTimeline() on the main UI thread. Call it delayed, in a Handler, or in a Timer Thread.

Here is a simple example:

Timer timer = new Timer();
timer.schedule(new TimerTask() {
    @Override
    public void run() {
        fetchTwitterPublicTimeline();
    }
}, 400);

A better practice would be to use a true Thread or better yet an AsyncTask. The reference has a very useful example.

David Manpearl
  • 12,362
  • 8
  • 55
  • 72
0

Caused by: android.os.NetworkOnMainThreadException, first read your exception and search for solution and if you don't find anything then post a question. The easiest solution its to use AsyncTask. that have doInBackGround() and onPostExecute().

//This Run in background
protected void doInBackground(String url){

//fetch objects
//parse objects

//it pass parsedObjects to onPostExecute method
 return parsedObjects;
} 

//This run on current thread (Ui thread in this case) 
protected void onPostExecute(ParsedObjects o){
//Receives parsedObejct from doInBackground
//update UI
}
Roger Garzon Nieto
  • 6,554
  • 2
  • 28
  • 24