如何让doInBackground方法工作?

时间:2013-02-12 10:28:49

标签: android asynchronous task

我的错误信息是:

>02-12 10:15:34.625: E/AndroidRuntime(1018): FATAL EXCEPTION: AsyncTask
> 1 02-12 10:15:34.625: E/AndroidRuntime(1018): java.lang.RuntimeException: An error occured while executing
> doInBackground() 02-12 10:15:34.625: E/AndroidRuntime(1018):  at
> android.os.AsyncTask$3.done(AsyncTask.java:200) 02-12 10:15:34.625:
> E/AndroidRuntime(1018):   at
> java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> java.util.concurrent.FutureTask.setException(FutureTask.java:124)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> java.util.concurrent.FutureTask.run(FutureTask.java:137) 02-12
> 10:15:34.625: E/AndroidRuntime(1018):     at
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> java.lang.Thread.run(Thread.java:1096) 02-12 10:15:34.625:
> E/AndroidRuntime(1018): Caused by: java.lang.NullPointerException
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> se.gibk.gibk.MainActivity$PostTask.GetList(MainActivity.java:88) 02-12
> 10:15:34.625: E/AndroidRuntime(1018):     at
> se.gibk.gibk.MainActivity$PostTask.doInBackground(MainActivity.java:143)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> se.gibk.gibk.MainActivity$PostTask.doInBackground(MainActivity.java:1)
> 02-12 10:15:34.625: E/AndroidRuntime(1018):   at
> android.os.AsyncTask$2.call(AsyncTask.java:185) 02-12 10:15:34.625:
> E/AndroidRuntime(1018):   at
> java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)

我的代码是:

 public class MainActivity extends Activity {

private static final String TAG = "Debugging";
private ListView list;
ArrayList<String> links;
Sermons sermons;


protected void onCreate(Bundle savedInstanceState) {
    Log.d(TAG, "MainActivity - OnCreate()");
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    new PostTask(this).execute("http://gibk.se/sample-page/predikningar/?podcast");
    Log.d(TAG, "execute");      

}

public class PostTask扩展了AsyncTask&gt; {

  private Context context;

  public PostTask(Context context) {
        this.context = context;

   }

 private ArrayList<Sermons> GetList(String url) {
        Log.d(TAG, "GetList");
        ArrayList<Sermons> results = new ArrayList<Sermons>();

           try {

                URL urls = new URL(url);


                XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
                factory.setNamespaceAware(false);
                XmlPullParser xmlParser = factory.newPullParser();
                xmlParser.setInput(this.getInputStream(urls), "UTF_8");

                boolean insideItem = false;

                int eventType = xmlParser.getEventType();
                while (eventType != XmlPullParser.END_DOCUMENT) {

                    if (eventType == XmlPullParser.START_TAG) {

                        if (xmlParser.getName().equalsIgnoreCase("item")) {
                            sermons = new Sermons();
                            insideItem = true;

                         } else if (xmlParser.getName().equalsIgnoreCase("title")) {

                             if (insideItem)
                                 sermons.setSermon(xmlParser.nextText()); 

                         } else if (xmlParser.getName().equalsIgnoreCase("itunes:author")) {

                             if (insideItem)
                                 sermons.setPreacher(xmlParser.nextText()); 

                         } else if (xmlParser.getName().equalsIgnoreCase("guid")) {
                             if (insideItem)
                               links.add(xmlParser.nextText());   

                         }

                        results.add(sermons);

                    }

                    else if(eventType==XmlPullParser.END_TAG && xmlParser.getName().equalsIgnoreCase("item")){

                        insideItem=false;
                    }

                     eventType = xmlParser.next();
                }

            }

             catch (MalformedURLException e) {
                 e.printStackTrace();

             }

            catch (XmlPullParserException e) {
                e.printStackTrace();

            }

            catch (IOException e) {
                e.printStackTrace();

            }

            return results;

    }

   private InputStream getInputStream(URL url) {

        try {

            return url.openConnection().getInputStream();

        } catch (IOException e) {

            return null;

        }
   }


@Override
protected ArrayList<Sermons> doInBackground(String... params) {
    Log.d(TAG, "doInBackGround");
    String url = params[0];
    ArrayList<Sermons> sermon = this.GetList(url);  
    return sermon;      

}

 @Override
 protected void onPostExecute(ArrayList<Sermons> result) {
         super.onPostExecute(result);
         Log.d(TAG, "onPostExecute");
        links = new ArrayList<String>();    
        list = (ListView) findViewById(R.id.list);
        list.setAdapter(new Adapter(MainActivity.this, (ArrayList<Sermons>) result));

        list.setOnItemClickListener(new OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> arg0, View v, int position,
                    long arg3) {

                Uri uri = Uri.parse(links.get(position));
                String url = uri.toString();

                Intent intent = new Intent(Intent.ACTION_VIEW);
                intent.setData(Uri.parse(url));
                startActivity(intent);

            }

        });
 }

} }

1 个答案:

答案 0 :(得分:0)

不确定它是否相关但是:

"title".equalsIgnoreCase(xmlParser.getName())

优于:

xmlParser.getName().equalsIgnoreCase("title")

减少NPE的机会。

另一个问题:

  private InputStream getInputStream(URL url) {

        try {

            return url.openConnection().getInputStream();

        } catch (IOException e) {

            return null;

        }
   }

异常时不应返回null,而是抛出异常。