Нужна помощь в решении проблемы фатального исключения, вызванного java.lang.IncompatibleClassChangeError
Так вот, вчера я столкнулся с этой ошибкой в Android Studio, которую я никогда раньше не видел, вызванной фрагментом кода, который не затрагивался в течение последних 3 месяцев. Это произошло из-за кода, который использовался для регистрации push-уведомлений и работал нормально на этой неделе, но теперь это приводит к этой ошибке:
05-20 10:37:02.064 22471-22681/com.appname E/AndroidRuntime: FATAL EXCEPTION: IntentService[RegIntentService]
Process: com.appname, PID: 22471
java.lang.IncompatibleClassChangeError: The method 'java.io.File android.support.v4.content.ContextCompat.getNoBackupFilesDir(android.content.Context)' was expected to be of type virtual but instead was found to be of type direct (declaration of 'java.lang.reflect.ArtMethod' appears in /system/framework/core-libart.jar)
at com.google.android.gms.iid.zzd.zzeb(Unknown Source)
at com.google.android.gms.iid.zzd.<init>(Unknown Source)
at com.google.android.gms.iid.zzd.<init>(Unknown Source)
at com.google.android.gms.iid.InstanceID.zza(Unknown Source)
at com.google.android.gms.iid.InstanceID.getInstance(Unknown Source)
at com.appname.services.RegistrationIntentService.onHandleIntent(RegistrationIntentService.java:32)
at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.os.HandlerThread.run(HandlerThread.java:61)
Вот мой класс RegistrationIntentService:
package com.appname.services;
import android.app.IntentService;
import android.content.Context;
import android.content.Intent;
import com.google.android.gms.gcm.GoogleCloudMessaging;
import com.google.android.gms.iid.InstanceID;
import com.appname.MainSharedPreferences;
import com.appname.R;
import java.io.IOException;
public class RegistrationIntentService extends IntentService {
private static final String TAG = "RegIntentService";
public RegistrationIntentService() {
super(TAG);
}
public static void startService(final Context context) {
final Intent intent = new Intent(context, RegistrationIntentService.class);
context.startService(intent); //HERE is the line that is causing the crash
}
@Override
public void onHandleIntent(Intent intent) {
InstanceID instanceID = InstanceID.getInstance(this);
try {
String token = instanceID.getToken(getString(R.string.gcm_defaultSenderId) , GoogleCloudMessaging.INSTANCE_ID_SCOPE, null);
MainSharedPreferences.saveGCMInstanceToken(token, getApplicationContext());
} catch (IOException e) {
e.printStackTrace();
}
}
Это строка кода, которая вызывает вышеуказанный класс из моего класса MainActivity:
RegistrationIntentService.startService(getApplicationContext());
Некоторая информация о моей MainActivity, если это поможет ...
public class MainActivity extends SocialActivity implements SeekBar.OnSeekBarChangeListener
public abstract class SocialActivity extends AppCompatActivity implements GraphRequest.GraphJSONObjectCallback
Я попытался вернуться к нескольким более старым коммитам, но получил ту же ошибку. Это заставило меня поверить, что, возможно, были проблемы с моей Android Studio или Java-версией. Я обновил свою версию Java и переустановил Android Studio, но та же ошибка. Также пробовал на отдельном компьютере с более старыми версиями, все та же ошибка.
Я даже пытался перейти с GCM на Firebase в соответствии сэто руководство и в итоге снова получаю ту же ошибку.
Я могу закомментировать строку, которая приводит к сбою приложения, и оно будет работать нормально, но тогда я больше не буду получать уведомления.
Любая помощь или совет по этому вопросу будет принята с благодарностью!
РЕДАКТИРОВАТЬ: Вот мои соответствующие инструкции compile / classpath ...
В имени приложения build.gradle:
buildscript {
repositories {
jcenter()
}
repositories { mavenCentral() }
dependencies {
classpath 'com.android.tools.build:gradle:2.1.0'
classpath 'com.google.gms:google-services:3.0.0'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
В приложении build.gradle:
apply plugin: 'com.android.application'
apply plugin: 'io.fabric'
repositories {
//...
}
allprojects {
//...
}
android {
//...
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.google.code.gson:gson:2.5'
compile 'com.android.support:design:23.4.0'
compile 'com.android.support:recyclerview-v7:+'
compile "com.google.firebase:firebase-messaging:9.0.0"
//...
}
apply plugin: 'com.google.gms.google-services'