私は初心者なので、我慢してください。
Webサービスから自分の近くの最も近い場所をプルする非同期タスクがあります。2.1以降の新しいAndroidデバイスで正常に動作します。2.1のHTCヒーローがいますが、ボタンを押してデータを見つけるたびにクラッシュします。
これが私が持っているコードです。最初の部分は、デバイスからlatとlongを取得し、サーバー上で作成したphpスクリプトに送信します。
private class DownloadWebPageTask extends AsyncTask<String, Void, String> {
@Override
protected String doInBackground(String... urls) {
//String response = "";
for (String url : urls) {
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost(url);
try {
// Add your data
List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
nameValuePairs.add(new BasicNameValuePair("lat", lat));
nameValuePairs.add(new BasicNameValuePair("long", longit));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
// Execute HTTP Post Request
UrlEncodedFormEntity ent = new UrlEncodedFormEntity(nameValuePairs,
HTTP.UTF_8);
httppost.setEntity(ent);
HttpResponse responsePOST = httpclient.execute(httppost);
responseBody = EntityUtils.toString(responsePOST.getEntity());
Log.i("YAhh", responseBody);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
} catch (IOException e) {
// TODO Auto-generated catch block
}
}
return responseBody;
}
この部分は、データを別のアクティビティに送信して、解析してリストビューに表示します。
@Override
protected void onPostExecute(String result) {
Log.i("returndata",responseBody);
/* Intent intent = new Intent(HomeActivity.this,
locationActivity.class);
Bundle bundle = new Bundle();
bundle.putString("returnBody", responseBody);
bundle.putString("latit", lat);
bundle.putString("longit" + "", longit);
intent.putExtras(bundle);
startActivity(intent);*/
}
}
これは私が受け取っているエラーです。データが返されていないため、null値がエラーの原因であることがわかります。
08-02 15:17:13.848: E/AndroidRuntime(1117): Uncaught handler: thread main exiting due to uncaught exception
08-02 15:17:13.968: E/AndroidRuntime(1117): java.lang.NullPointerException: println needs a message
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.util.Log.println(Native Method)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.util.Log.i(Log.java:136)
08-02 15:17:13.968: E/AndroidRuntime(1117): at com.mlgw.mlgwapp.HomeActivity$DownloadWebPageTask.onPostExecute(HomeActivity.java:278)
08-02 15:17:13.968: E/AndroidRuntime(1117): at com.mlgw.mlgwapp.HomeActivity$DownloadWebPageTask.onPostExecute(HomeActivity.java:1)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.os.AsyncTask.finish(AsyncTask.java:417)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.os.AsyncTask.access$300(AsyncTask.java:127)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.os.Handler.dispatchMessage(Handler.java:99)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.os.Looper.loop(Looper.java:123)
08-02 15:17:13.968: E/AndroidRuntime(1117): at android.app.ActivityThread.main(ActivityThread.java:4595)
08-02 15:17:13.968: E/AndroidRuntime(1117): at java.lang.reflect.Method.invokeNative(Native Method)
08-02 15:17:13.968: E/AndroidRuntime(1117): at java.lang.reflect.Method.invoke(Method.java:521)
08-02 15:17:13.968: E/AndroidRuntime(1117): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
08-02 15:17:13.968: E/AndroidRuntime(1117): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
08-02 15:17:13.968: E/AndroidRuntime(1117): at dalvik.system.NativeStart.main(Native Method)
なぜこれが2.1で機能しないのかについて誰かが手がかりを持っていますか?どんな助けでもいただければ幸いです。