今天写代码时,还遇到了如下的错误消息:

04-08 21:55:22.792: W/System.err(10665): org.json.JSONException: End of input at character 0 of
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONTokener.syntaxError(JSONTokener.java:446)
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONTokener.nextValue(JSONTokener.java:93)
04-08 21:55:22.802: W/System.err(10665): at org.json.JSONArray.<init>(JSONArray.java:87)
04-08 21:55:22.812: W/System.err(10665): at org.json.JSONArray.<init>(JSONArray.java:103)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.service.GetNews.GetJSON(GetNews.java:65)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.service.GetNews.getNewsListByJSON(GetNews.java:48)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.news.NewsActivity.fillListView(NewsActivity.java:29)
04-08 21:55:22.812: W/System.err(10665): at cn.jbit.news.NewsActivity.onCreate(NewsActivity.java:24)
04-08 21:55:22.812: W/System.err(10665): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
04-08 21:55:22.812: W/System.err(10665): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
04-08 21:55:22.822: W/System.err(10665): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
04-08 21:55:22.822: W/System.err(10665): at android.os.Handler.dispatchMessage(Handler.java:99)
04-08 21:55:22.822: W/System.err(10665): at android.os.Looper.loop(Looper.java:123)
04-08 21:55:22.822: W/System.err(10665): at android.app.ActivityThread.main(ActivityThread.java:3683)
04-08 21:55:22.832: W/System.err(10665): at java.lang.reflect.Method.invokeNative(Native Method)
04-08 21:55:22.832: W/System.err(10665): at java.lang.reflect.Method.invoke(Method.java:507)
04-08 21:55:22.832: W/System.err(10665): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-08 21:55:22.832: W/System.err(10665): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-08 21:55:22.832: W/System.err(10665): at dalvik.system.NativeStart.main(Native Method)

我们先直译一下错误消息的意思:在输入端字符0结尾处抛出了JSONException;

后然,发现了错误的原因:

/**
* 读取 流数据
* @param input
* @return
* @throws Exception
*/

public static byte[] read(InputStream input) throws Exception {
ByteArrayOutputStream out =new ByteArrayOutputStream();
byte[] data =new byte[1024];
int len =0;
while((len=input.read(data))!=-1){
out.write(data, 0, 0); //原本应该是out.write(data, 0,len);,但当时用了快捷键,打成了0,就抛出了如上的异常消息
}
out.close();
return out.toByteArray();
}

看了上面的代码,我想你也知道我抛出这个异常的原因了吧;再看看下面的代码:

/***
* 从服务器 返回JSON 数据 并在这里进行解析
* @param input
* @return
* @throws Exception
*/

private static List<News> GetJSON(InputStream input) throws Exception {
List<News> list =new ArrayList<News>();
byte[] data =StreamTool.read(input);
String json =new String (data); // 从 服务器 传过来的数据 产用的编码就是 utf-8 这里就不写了
JSONArray array =new JSONArray(json);
for(int i =0 ; i<array.length();i++){
JSONObject jsonObject =array.getJSONObject(i);
News news =new News();
news.setNid(jsonObject.getInt("id"));
news.setNauthor(jsonObject.getString("author"));
news.setNtitle(jsonObject.getString("title"));
list.add(news);
}
return list;
}

我当时调用了第一个方法read(InputStream input)方法,因为不小心打错了代码,该方法返回的值肯定是什么字节,那么在解析JSON 肯定是在索引为0位置的字符处就出现异常!

更多相关文章

  1. 友盟推送android 8.0系统不显示推送消息问题
  2. Android(安卓)Wifi子系统源代码View
  3. Android(安卓)APK瘦身之Android(安卓)Studio Lint (代码审查)
  4. Android(安卓)Studio(十一):代码混淆及打包apk
  5. android通知栏消息
  6. Android(安卓)分析:Process xxxxx (pid 30262) has died .
  7. android的Menu使用
  8. 代码:android崩溃日志收集和处理
  9. Android关于 'roundIcon' in package '的错误

随机推荐

  1. android用户界面详尽教程实例
  2. Android(安卓)- ScrollView嵌套ListView~
  3. Android的两个bugs
  4. Android(安卓)监控程序安装和删除的实现
  5. Android计算地图上两点距离
  6. 工具:Android本地代码生成器
  7. Android(安卓)实践项目开发 总结
  8. Android彩蛋效果,微信彩蛋效果
  9. Android(安卓)studio 运行即打包keystore
  10. 2011.07.08(3)——— android AlarmManager