Я занимаюсь разработкой приложения для системы Android, которое включает в себя анализ некоторых XML-материалов.Проблема в том, что программа падает, и я не обнаружил проблему.У меня есть активность, которая имеет закрытый класс, который расширяет асинхронную задачу.Это код:
URL url = new URL(XML_INIT_ADRESS);
XmlPullParser xpp = XmlPullParserFactory.newInstance().newPullParser();
xpp.setInput(url.openConnection().getInputStream(), null);
int pullParserState = xpp.getEventType();
while (pullParserState != XmlPullParser.END_DOCUMENT){
if (xpp.getName().equals("signupclients") && pullParserState == XmlPullParser.START_TAG){ //Error!!!
while(!xpp.getName().equals("signupclients") && pullParserState != XmlPullParser.END_TAG){
if (xpp.getName().equals("client")) {
clientNames.add(xpp.getAttributeValue(0));
}
pullParserState = xpp.next();
}
pullParserState = xpp.next();
}
}
Как вы можете заметить, я прокомментировал первый оператор if, который, если вы закомментируете это, и код, содержащий код, будет работать.Могу добавить, что это в Eclipse и я ловлю все ошибки.
String XML_INIT_ADRESS = "http://www.johanstenberg.se/tests/app/start.xml"
Это должен быть действительный XML-документ.Пожалуйста, помогите, потому что я не знаю, но я хочу, чтобы он работал с XMLPullParser.Я вызываю asynctask, который в методе onCreate () выглядит следующим образом:
new UpdateDatabase().execute();
Где UpdateDatabase - это имя частного класса, расширяющего Asynctask.
Заранее спасибо!
Logcat:
12-05 18:38:43.664: W/KeyCharacterMap(525): No keyboard for id 0
12-05 18:38:43.664: W/KeyCharacterMap(525): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
12-05 18:38:44.854: I/AndroidRuntime(525): AndroidRuntime onExit calling exit(0)
12-05 18:38:45.154: D/dalvikvm(535): GC freed 750 objects / 54888 bytes in 51ms
12-05 18:38:45.584: W/dalvikvm(535): threadid=15: thread exiting with uncaught exception (group=0x4001b188)
12-05 18:38:45.594: E/AndroidRuntime(535): Uncaught handler: thread AsyncTask #1 exiting due to uncaught exception
12-05 18:38:45.604: E/AndroidRuntime(535): java.lang.RuntimeException: An error occured while executing doInBackground()
12-05 18:38:45.604: E/AndroidRuntime(535): at android.os.AsyncTask$3.done(AsyncTask.java:200)
1 2-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.lang.Thread.run(Thread.java:1096)
12-05 18:38:45.604: E/AndroidRuntime(535): Caused by: java.lang.NullPointerException
12-05 18:38:45.604: E/AndroidRuntime(535): at com.discountapp.johanaugust.UpdatingDB$UpdateDatabase.doInBackground(UpdatingDB.java:119)
12-05 18:38:45.604: E/AndroidRuntime(535): at com.discountapp.johanaugust.UpdatingDB$UpdateDatabase.doInBackground(UpdatingDB.java:1)
12-05 18:38:45.604: E/AndroidRuntime(535): at android.os.AsyncTask$2.call(AsyncTask.java:185)
12-05 18:38:45.604: E/AndroidRuntime(535): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
12-05 18:38:45.604: E/AndroidRuntime(535): ... 4 more
12-05 18:38:45.654: I/dalvikvm(535): threadid=7: reacting to signal 3
12-05 18:38:45.654: E/dalvikvm(535): Unable to open stack trace file '/data/anr/traces.txt': Permission denied