我注意到错误监控工具中出现了一堆错误,与FirebaseInstanceIdService连接:
. lang。注册太多的广播接收器1 .在android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1838)2 . at android.app.ContextImpl.registerReceiver(ContextImpl.java:1794)3 . at android.app.ContextImpl.registerReceiver(ContextImpl.java:1788)4 . at android.content. contextrapper . registerreceiver (contextrapper .java:489)firebaseinstanceidservice .boolean zzag(android.content.Intent)(来源未知)6
发生在运行Android 5.1的HUAWEI RIO-L01设备上,并且:
ava.lang。@从pid 25905 uid 10022注册的告警太多(500)1 . android.os. par塞尔. readexeption (par塞尔.java:1546)2 .在android.os. par塞尔. readexeption (par塞尔.java:1499)3 . at android.app.IAlarmManager$Stub$Proxy.set(IAlarmManager.java:206)4 . at android.app.AlarmManager.setImpl(AlarmManager.java:428)5 . at android.app.AlarmManager.set(AlarmManager.java:215)6 . at com.google.firebase.iid.FirebaseInstanceIdService.void zzah(android.content.Intent)(未知来源)
发生在运行Android 5.1.1的三星SM-G800F上。有人知道是怎么回事吗?
我怀疑这可能是由电话供应商代码引起的,而不是由Firebase引起的,但它仍然扰乱了我的崩溃率统计,所以如果可能的话,我想解决它。
错误开始于最近的应用程序发布,但它相关的FCM代码比这更老,这就是为什么我希望它是可以避免的。我不确定是什么变化促成了它,没有什么直接与FCM相关的,我可以分离出来。
我使用Firebase 9.6.1,构建工具24.0.2,targetSdk 19, minSdk 14。
下面是应用的gradle文件(删除了测试、变体和不相关的构建类型):
apply plugin: 'com.android.application'
apply plugin: 'com.getkeepsafe.dexcount'
android {
compileSdkVersion 24
buildToolsVersion '24.0.2'
dataBinding {
enabled = true
}
defaultConfig {
applicationId 'hr.doesnt.matter'
minSdkVersion 14
targetSdkVersion 19
versionName '1.3.5.4'
versionCode 13540
multiDexEnabled true
}
buildTypes {
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-android.pro'
signingConfig signingConfigs.release
}
dexOptions {
preDexLibraries true
javaMaxHeapSize "6g" // Use gig increments depending on needs
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar', '*.aar'])
// - SUPPORT LIBS
compile 'com.android.support:appcompat-v7:24.2.1'
compile 'com.android.support:recyclerview-v7:24.2.1'
compile 'com.android.support:design:24.2.1'
compile 'com.android.support:multidex:1.0.1'
compile 'com.android.support:percent:24.2.1'
// - GOOGLE SERVICES
compile 'com.google.android.gms:play-services-base:9.6.1'
compile 'com.google.android.gms:play-services-analytics:9.6.1'
compile 'com.google.firebase:firebase-messaging:9.6.1'
compile 'com.google.firebase:firebase-config:9.6.1'
// - FONTS
compile 'uk.co.chrisjenx:calligraphy:2.2.0'
// - TOOLS
compile 'com.fasterxml.jackson.core:jackson-databind:2.5.2'
compile 'com.fasterxml.jackson.core:jackson-core:2.5.2'
compile 'com.koushikdutta.async:androidasync:2.1.7'
compile 'com.splunk.mint:mint:5.0.0'
compile 'nf.fr.eraasoft:objectpool:1.1.2'
compile 'com.google.android.exoplayer:exoplayer:r1.5.2'
// - RX
compile 'io.reactivex:rxandroid:1.1.0'
compile 'com.trello:rxlifecycle:0.5.0'
compile 'com.trello:rxlifecycle-components:0.5.0'
}
configurations.all {
resolutionStrategy {
force "com.android.support:support-annotations:24.2.1"
force "com.android.support:support-v4:24.2.1"
}
}
apply plugin: 'com.google.gms.google-services'
项目gradle文件:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.2.0'
classpath 'com.getkeepsafe.dexcount:dexcount-gradle-plugin:0.5.0'
classpath 'com.google.gms:google-services:3.0.0'
}
}
allprojects {
repositories {
jcenter()
maven { url "https://mint.splunk.com/gradle/" }
maven { url "https://oss.sonatype.org/content/repositories/snapshots/" }
}
}
所有来自firebase的库都需要在app.gradle:
'com.google.firebase:firebase-core:9.6.1'
添加了这个,如果有任何错误告诉我,问候!
似乎后续的库版本(至少Firebase 9.8.0)已经纠正了这种情况,因为我不再看到它发生了。真正的原因仍然是个谜。:)