java - 为什么 Android 中不缓存 JSON 异常?

标签 java android json exception

我有以下代码,但有时我有以下未捕获的异常..原因和解决方案是什么?

12-02 12:03:29.101: ERROR/AndroidRuntime(348): FATAL EXCEPTION: main
12-02 12:03:29.101: ERROR/AndroidRuntime(348): java.lang.RuntimeException: Unable to start activity ComponentInfo{ayanoo.forms/ayanoo.forms.FriendsActivity}: java.lang.NullPointerException
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.os.Handler.dispatchMessage(Handler.java:99)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.os.Looper.loop(Looper.java:123)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread.main(ActivityThread.java:4627)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at java.lang.reflect.Method.invokeNative(Native Method)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at java.lang.reflect.Method.invoke(Method.java:521)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at dalvik.system.NativeStart.main(Native Method)
12-02 12:03:29.101: ERROR/AndroidRuntime(348): Caused by: java.lang.NullPointerException
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at org.json.JSONTokener.nextCleanInternal(JSONTokener.java:112)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at org.json.JSONTokener.nextValue(JSONTokener.java:90)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at org.json.JSONObject.<init>(JSONObject.java:154)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at org.json.JSONObject.<init>(JSONObject.java:171)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at ayanoo.forms.FriendsActivity.displayFriends(FriendsActivity.java:79)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at ayanoo.forms.FriendsActivity.onCreate(FriendsActivity.java:36)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
12-02 12:03:29.101: ERROR/AndroidRuntime(348):     ... 11 more





try {
            //  String searchText = (String) getIntent().getExtras().get("searchTextValue");
            JSONObject jsonObject = new JSONObject(Friend.getFriends(1));
            if(jsonObject!=null)
                    {
                JSONArray resultsData = jsonObject.getJSONArray("GetFriendsResult");
                for (int userIndex = 0; userIndex < resultsData.length(); userIndex++) {
                    if (friendsResulted == null) {
                        friendsResulted = new ArrayList<FriendResulted>(resultsData.length());
                    }
                    String[] userArrayData = resultsData.getString(userIndex).split("--!!--");
                    FriendResulted frindAccountResulted = new FriendResulted();

                    frindAccountResulted.setFriendId(Integer.parseInt(userArrayData[0]));
                    frindAccountResulted.setUsername(userArrayData[1]);
                    frindAccountResulted.setImagePath(userArrayData[2]);
                    friendsResulted.add(frindAccountResulted);
                    addFriend(frindAccountResulted);
                    counter ++;
                    if(counter>9)break;
                }


                }
            }

        catch (JSONException e) {
                Toast.makeText(this,"Please try again, "+e.getMessage() , Toast.LENGTH_SHORT).show();
                }

最佳答案

这是一个NullPointerException,而不是一个JSONEcxeption。我认为这是由这一行引起的:

JSONObject jsonObject = new JSONObject(Friend.getFriends(1));

看起来 Friend.getFriends(1) 返回 null。你必须改变这一点。

关于java - 为什么 Android 中不缓存 JSON 异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4291572/

相关文章:

java - java中的Double {{ }}语法问题

java - Libsvm java训练测试示例(也是实时的)

java - 从 onPostExecute 中的另一个类调用方法导致 nullPointerException

iOS 5 - 无法将十六进制转义序列(无高位字符)转换为 UTF8 编码字符

javascript - 循环每个输入的相对记录并纠正重复记录

python - 如何访问广播变量的内容

javascript - 添加带有 composant h :commandButton 的特定确认弹出窗口

java - DBUnit 当前线程被中断

android - 在没有工具栏的情况下使用 AppBarLayout 和 CollapsingToolbarLayout

android - 遍历列表并单击 Robotium 中的列表项