警报/接收器错误太多



我注意到错误监控工具中出现了一堆错误,与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)已经纠正了这种情况,因为我不再看到它发生了。真正的原因仍然是个谜。:)

最新更新