2015-10-15 43 views
0

如何正確處理throwIndexOutOfBoundsException?基本上,我正在查詢用戶。如果用戶存在,則顯示他們的個人資料。但是,如果找不到條目,​​它會崩潰我的應用程序並拋出異常。我應該在我的「其他」語句中放入什麼,以便應用程序不會崩潰?ParseQuery - 正確處理IndexOutOfBoundsException - Parse.com?

    @Override 
        public void done(List<ParseUser> parseUsers, ParseException e) { 
          if (e == null) { 
            // The query was successful. 
            ParseUser user = parseUsers.get(0); 
            String userId = user.getObjectId(); 
            showProfileActivity(userId); 

          } else { 
           // The query was unsuccessful. 

          } 
         } 
        }); 

這裏是logcat的:

10-14 21:27:06.888 28595-28595/com.app.social E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    Process: com.elgami.customizer, PID: 28595 
    java.lang.IndexOutOfBoundsException: Invalid index 0, size is 0 
      at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:255) 
      at java.util.ArrayList.get(ArrayList.java:308) 
      at com.elgami.feed.SearchActivity$1$1.done(SearchActivity.java:74) 
      at com.elgami.feed.SearchActivity$1$1.done(SearchActivity.java:67) 
      at com.parse.Parse$6$1.run(Parse.java:944) 
      at android.os.Handler.handleCallback(Handler.java:739) 
      at android.os.Handler.dispatchMessage(Handler.java:95) 
      at android.os.Looper.loop(Looper.java:148) 
      at android.app.ActivityThread.main(ActivityThread.java:5417) 
      at java.lang.reflect.Method.invoke(Native Method) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 

回答

2

你可以檢查列表爲空:

@Override 
     public void done(List<ParseUser> parseUsers, ParseException e) { 
           if (!parseUsers.isEmpty()) { 
             // The query was successful. 
             ParseUser user = parseUsers.get(0); 
             String userId = user.getObjectId(); 
             showProfileActivity(userId); 

           } else { 
            // The query was unsuccessful. 

           } 
          } 
         }); 

,或者如果你想趕上異常使用嘗試-catch是這樣的:

@Override 
    public void done(List<ParseUser> parseUsers, ParseException e) { 
      if (e==null) { 
      // The query was successful. 
      try{ 
       ParseUser user = parseUsers.get(0); 
       String userId = user.getObjectId(); 
      } 
     catch(ArrayIndexOutOfBoundsException e) 
      { 
     // Print message for user does not exist . 
      } 
      showProfileActivity(userId); 
      } 
       else { 
        // The query was unsuccessful. 
        } 
         } 
          }); 
+1

我本來應該說的相同 – Apurva

+1

太棒了!我去了第一個選項,檢查一個空的列表。 try/catch方法或多或少是普遍的,並且在最佳實踐方面使用其他方法有什麼特別的考慮?無論哪種方式,奇妙地工作。 – drearypanoramic

+2

捕捉如果我們想根據特定的異常向用戶顯示特定的消息,那麼Exception是非常好的。但是他們會讓程序變慢一點。而通過像方案1那樣事先檢查例外情況,我們在代碼中阻止了它的產生。這是更好的方式,因爲它會比選項2更快。請閱讀更多信息:https://docs.oracle.com/javase/tutorial/essential/exceptions/advantages.html和http://stackoverflow.com/questions/299068/how-slow-are-java-exceptions。 – WannaBeGeek