Я получил странное исключение из-за ограничений в консоли Play Store, относящееся к 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)
Это моя реализация 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);
}
}
Строка 2068 такова:
if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Я считаю, что утверждение grantResults
length равно нулю, поэтому генерируется исключение java.lang.ArrayIndexOutOfBoundsException. Согласно документации
int: результаты предоставления для соответствующих разрешений, которые либо PERMISSION_GRANTED или PERMISSION_DENIED. Никогда не имеет значения.
grantResults
не будет null, но ничего не говорит об этом, не содержащем значения. Кроме того, похоже, что обратный вызов будет содержать хотя бы одно значение: PERMISSION_GRANTED
или PERMISSION_DENIED
. Является ли это ошибкой или я не понимаю документацию?