【发布时间】:2015-08-16 09:00:00
【问题描述】:
我的 XML 文件:
<job_id>000273E060E87000C0001323FA21427120150602153306</job_id>
<job_id>000273E060E87000C0001323FA21427120150602153342</job_id>
<job_id>000273E060E87000C0001323FA21427120150602153419</job_id>
我在这里得到一个 NullPointerException:
protected ArrayList<HashMap<String, String>> doInBackground(URL... urls) {
if (cd.isConnectingToInternet()) {
XMLParser xmlParser = new XMLParser();
String xml = xmlParser.getXMLFromUrl("http://www.example.de/android.php?f=1200");
Document doc = xmlParser.getDomElement(xml);
writeToFile(xml, "xmlfilesnames");
NodeList noteListFileNames = doc.getElementsByTagName("tasklist");
for (int i = 0; i <= noteListFileNames.getLength(); i++) {
HashMap<String, String> map = new HashMap<String, String>();
Element e = (Element) noteListFileNames.item(i);
map.put("job_id", xmlParser.getValue(e, "job_id"));
xmlFileNames.add(map);
}
在:map.put("job_id", xmlParser.getValue(e, "job_id")); for 循环第二次运行时。
堆栈跟踪:
java.lang.RuntimeException: An error occured while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:300)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:841)
Caused by: java.lang.NullPointerException
at xmlParsing.XMLParser.getValue(XMLParser.java:88)
at de.example.app.ListViewActivity$DownloadXMLFilesName.doInBackground(ListViewActivity.java:298)
at de.example.app.ListViewActivity$DownloadXMLFilesName.doInBackground(ListViewActivity.java:281)
at android.os.AsyncTask$2.call(AsyncTask.java:288)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
在 android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 在 java.lang.Thread.run(Thread.java:841)
XML 文件如下所示:
<?xml version="1.0" encoding="utf-8"?>
<tasklist>
<job_id>000273E060E87000C0001323FA21427120150602153306</job_id>
<job_id>000273E060E87000C0001323FA21427120150602153342</job_id>
<job_id>000273E060E87000C0001323FA21427120150602153419</job_id>
</tasklist>
第一个循环
xml文件名:
000273E060E87000C0001323FA21427120150602153419
地图:
000273E060E87000C0001323FA21427120150602153419
第二次循环 xml文件名:
000273E060E87000C0001323FA21427120150602153342
000273E060E87000C0001323FA21427120150602153342
地图:
000273E060E87000C0001323FA21427120150602153342
第三循环
xml文件名
000273E060E87000C0001323FA21427120150602153419
000273E060E87000C0001323FA21427120150602153419
000273E060E87000C0001323FA21427120150602153419
地图:
000273E060E87000C0001323FA21427120150602153419
【问题讨论】:
-
请发布堆栈跟踪,因为我们还不知道 NPE 被准确抛出的位置。
-
哦,对不起...我已经发布了我的堆栈跟踪