2016-06-22 9 views
20

dostałam dziwne poza granicami wyjątku w konsoli Sklep Play dotycząca android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallbackStrange ArrayIndexOutOfBoundsException w android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback

java.lang.ArrayIndexOutOfBoundsException: length=0; index=0 
    at com.example.MyFragmentActivity.onRequestPermissionsResult(MyFragmentActivity.java:2068) 
    at android.app.Activity.requestPermissions(Activity.java:4163) 
    at android.support.v4.app.ActivityCompatApi23.requestPermissions(ActivityCompat23.java:32) 
    at android.support.v4.app.ActivityCompat.requestPermissions(ActivityCompat.java:316) 
    at com.example.MyFragmentActivity.onConnected(MyFragmentActivity.java:2048) 
    at com.google.android.gms.common.internal.zzk.zzk(Unknown Source) 
    at com.google.android.gms.common.api.internal.zzj.zzi(Unknown Source) 
    at com.google.android.gms.common.api.internal.zzh.zzpx(Unknown Source) 
    at com.google.android.gms.common.api.internal.zzh.onConnected(Unknown Source) 
    at com.google.android.gms.common.api.internal.zzl.onConnected(Unknown Source) 
    at com.google.android.gms.common.api.internal.zzc.onConnected(Unknown Source) 
    at com.google.android.gms.common.internal.zzj$zzg.zzqL(Unknown Source) 
    at com.google.android.gms.common.internal.zzj$zza.zzc(Unknown Source) 
    at com.google.android.gms.common.internal.zzj$zza.zzw(Unknown Source) 
    at com.google.android.gms.common.internal.zzj$zzc.zzqN(Unknown Source) 
    at com.google.android.gms.common.internal.zzj$zzb.handleMessage(Unknown Source) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:158) 
    at android.app.ActivityThread.main(ActivityThread.java:7229) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 

To moja realizacja onRequestPermissionsResult

@Override 
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { 
    switch (requestCode) { 
     case REQUEST_CODE_ASK_LOCATION_PERMISSIONS: 
      if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { 
       // Permission Granted 
       if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { 
        mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient); 
       } 
       startLocationUpdates(); 
      } else { 
       // Permission Denied 
      } 
      break; 
     default: 
      super.onRequestPermissionsResult(requestCode, permissions, grantResults); 
    } 
} 

Linia 2068 to:

if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { 

Wierzę, że to jest twierdzenie, że długość grantResults wynosi zero, dlatego generowany jest wyjątek java.lang.ArrayIndexOutOfBoundsException. Według documentation

Int: Wyniki grantów dla odpowiednich uprawnień, który jest albo PERMISSION_GRANTED lub PERMISSION_DENIED. Nigdy nie zeruj.

grantResults nie będzie zerowy, ale nie mówi nic o tym nie zawierający wartość albo. Ponadto wygląda na to, że callback będzie zawierał co najmniej jedną wartość, PERMISSION_GRANTED lub PERMISSION_DENIED. Czy to błąd, czy też nie rozumiem dokumentacji?

Odpowiedz

32

Documentation about permissions mówi

Jeśli wniosek zostanie anulowany, tablice wynikowe są puste.

I wydaje się być sytuacja, więc trzeba najpierw sprawdzić, czy tablica nie jest pusty:

@Override 
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { 
    switch (requestCode) { 
     case REQUEST_CODE_ASK_LOCATION_PERMISSIONS: 
      if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { 
       // Permission Granted 
       if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { 
        mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient); 
       } 
       startLocationUpdates(); 
      } else { 
       // Permission Denied 
      } 
      break; 
     default: 
      super.onRequestPermissionsResult(requestCode, permissions, grantResults); 
    } 
} 
+1

Tak, że to przypadek. Świetna odpowiedź. – jnellen

+0

Awesome. To prawda. –

+0

Czy ktoś wie, co oznacza "żądanie anulowane"? Kto to anulował? Nie znam żadnego interfejsu API, aby anulować żądanie i nie rozumiem, w jaki sposób użytkownik może je anulować, gdy jest to wyraźnie "tak" lub "nie" dla użytkownika ... – user3175580

Powiązane problemy