Android从其他Web服务获取数据
我希望主要活动从一个其他Web服务获取一些数据。对于这项工作,我使用AsyncTask来连接Web服务。在onCreate方法中显示XML布局文件时,它将显示来自Web服务的数据,该应用程序可以成功运行。但是,当onCreate方法显示不同的XML布局文件时,将显示来自Web服务的数据的布局文件中,应用程序不起作用,并且logcats在从Web服务获取的数据中显示NullPointerException。Android从其他Web服务获取数据
public class MainActivity extends Activity
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.splash_screen);
new DownloadSights().execute();
}
class DownloadSights extends AsyncTask< Void, Void, Places >
{
@Override
protected void onPreExecute()
{
super.onPreExecute();
}
@Override
protected ListKozanisPlaces doInBackground(Void... params)
{
try
{
final String url = "http://192.168.1.3:8080/.../getSights";
InputStreamReader reader = new InputStreamReader(new URL(url).openStream());
Places sightsList = new Gson().fromJson(reader, Places.class);
return sightsList;
}
catch (Exception e)
{
Log.e("CityCuide", e.getMessage());
}
return null;
}
@Override
protected void onPostExecute(Places sightsList)
{
TextView testTextView = (TextView) findViewById(R.id.testTextView);
testTextView.setText(sightsList.getList().get(1).toString());
}
}
}
位于行中的错误:
testTextView.setText(sightsList.getList()得到(1)的ToString());
logcat中显示:
01-22 01:31:12.211: E/AndroidRuntime(5455): FATAL EXCEPTION: main
01-22 01:31:12.211: E/AndroidRuntime(5455): java.lang.NullPointerException
01-22 01:31:12.211: E/AndroidRuntime(5455): at com.example.androidkozaniwebserviceclient.SplashScreenActivity$DownloadSights.onPostExecute(SplashScreenActivity.java:66)
01-22 01:31:12.211: E/AndroidRuntime(5455): at com.example.androidkozaniwebserviceclient.SplashScreenActivity$DownloadSights.onPostExecute(SplashScreenActivity.java:1)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.os.AsyncTask.finish(AsyncTask.java:602)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.os.AsyncTask.access$600(AsyncTask.java:156)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:615)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.os.Handler.dispatchMessage(Handler.java:99)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.os.Looper.loop(Looper.java:137)
01-22 01:31:12.211: E/AndroidRuntime(5455): at android.app.ActivityThread.main(ActivityThread.java:4424)
01-22 01:31:12.211: E/AndroidRuntime(5455): at java.lang.reflect.Method.invokeNative(Native Method)
01-22 01:31:12.211: E/AndroidRuntime(5455): at java.lang.reflect.Method.invoke(Method.java:511)
01-22 01:31:12.211: E/AndroidRuntime(5455): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
01-22 01:31:12.211: E/AndroidRuntime(5455): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
01-22 01:31:12.211: E/AndroidRuntime(5455): at dalvik.system.NativeStart.main(Native Method)
如果装入不同的XML布局,它不会有一个名为testTextView TextView的。这将使findViewById返回null。当你尝试调用setText时,会在onPostExecute中导致NullPointerException。
这个问题是一种微不足道的,但在将来请附上任何崩溃的bug的堆栈跟踪。
如果我使用的文本文件,从Web服务保存数据,应用程序不会因为同样的错误工作... –
它没有任何使用web服务,它与将数据加载到UI中有关。 –
你可以发布你的布局XML文件,以便我们可以确定吗? –
确定sightsList
不是null,如果你确信Gabe的答案。 我建议你将testTextView.setText(sightsList.getList().get(1).toString());
分成几部分,以便轻松找出发生的事情。
List targetList = sightsList.getList();
String data = targetList.get(1).toString(); // this index 1 might return null also
textTextView.setText(data);
sightsList不为空,因为当onCreate()方法显示XML布局文件时,它将显示来自Web服务的数据,应用程序可以成功运行。我用一个文件改变TextViews,但现在我有NullPointerException在:outputStream.println(sightsList.getList()。get(1).toString()); –
很明显,问题在于sListList.getList()。get(1).toString()部分。你在索引1处得到什么?您是否按照我的建议尝试破解代码? –
请发表您的logcat –
编辑我的帖子.. –