Google Play服务升级至9.0.0后,应用程序在DynamiteModulesC中挂起

16

使用这些更改和重新生成的google-services.json将正在开发中的应用程序升级到9.0.0:

classpath 'com.google.gms:google-services:3.0.0'
compile 'com.google.android.gms:play-services:9.0.0'

升级后,当应用程序初始化时,预期的logcat消息序列会出现。大约7秒钟后,相同的消息序列会再次输出,并添加了header background_crash。例如:



17:39:30.162 5453-5453/com.xxx.nub:background_crash I/MultiDex: install done

应用程序在正常情况下运行,直到它被隐藏,例如通过在另一个应用程序中启动活动。5秒钟后,系统检测到应用程序挂起:

05-20 17:40:10.315 5138-5138/com.xxx.nub I/MainActivity: STOP MainActivity
05-20 17:40:10.375 5138-5138/com.xxx.nub I/NubApplication: onTrimMemory(): TRIM_MEMORY_UI_HIDDEN
05-20 17:40:10.375 5138-5138/com.xxx.nub D/FirebaseApp: Notifying background state change listeners.
05-20 17:45:10.465 5138-5143/com.xxx.nub I/dalvikvm: threadid=3: reacting to signal 3
05-20 17:45:10.565 5138-5143/com.xxx.nub I/dalvikvm: Wrote stack traces to '/data/anr/traces.txt'

堆栈跟踪显示该应用程序在 com.google.android.gms.DynamiteModulesC 中挂起。

----- pid 5138 at 2016-05-20 17:45:10 -----
Cmd line: com.xxx.nub

JNI: CheckJNI is off; workarounds are off; pins=0; globals=295

DALVIK THREADS:
(mutexes: tll=0 tsl=0 tscl=0 ghl=0)

"main" prio=5 tid=1 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x416c5ea0 self=0x415bb5d0
  | sysTid=5138 nice=-11 sched=0/0 cgrp=apps handle=1073844564
  | state=S schedstat=( 0 0 0 ) utm=1774 stm=244 core=1
  at java.lang.Object.wait(Native Method)
  - waiting on <0x42804a68> (a aaf)
  at java.lang.Object.wait(Object.java:364)
  at aaf.a(:com.google.android.gms.DynamiteModulesC:75)
  at zq.onTrimMemory(:com.google.android.gms.DynamiteModulesC:1187)
  at android.app.Application.onTrimMemory(Application.java:148)
  at com.xxx.nub.NubApplication.onTrimMemory(NubApplication.java:211)
  at android.app.ActivityThread.handleTrimMemory(ActivityThread.java:4298)
  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1481)
  at android.os.Handler.dispatchMessage(Handler.java:102)
  at android.os.Looper.loop(Looper.java:146)
  at android.app.ActivityThread.main(ActivityThread.java:5487)
  at java.lang.reflect.Method.invokeNative(Native Method)
  at java.lang.reflect.Method.invoke(Method.java:515)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
  at dalvik.system.NativeStart.main(Native Method)

该问题出现在运行KitKat操作系统的手机上。该问题不会在运行Lollipop操作系统的手机上出现。

完整的logcat输出可以在这里查看。

1个回答

23

background_crash进程是由Firebase崩溃报告创建的。这就是为什么你看到了重复的消息,但我不认为它是根本原因。我将会向Google Play服务团队反馈此问题,但在此期间,您可以使用解决方法:

因为您指定com.google.android.gms:play-services:9.0.0作为依赖项,所以您实际上引入了所有Google Play服务 - 这很多!

我建议您用您需要的特定依赖项替换该行代码。您可以在此处找到完整列表。例如,如果您正在使用地图和Google登录,则可以指定:

compile 'com.google.android.gms:play-services-auth:9.0.0'
compile 'com.google.android.gms:play-services-maps:9.0.0'

2
正如您建议的那样,我用七个特定的依赖项替换了play-services的依赖项。这个改变消除了挂起和许多Firebase相关的警告信息在logcat中。感谢您的答案和提交问题。 - Bob Snyder
@IanBarber 这是否意味着 classpath 'com.google.gms:google-services:3.0.0' 仍将包含在项目级别的 gradle 中? - Paula Kristin
1
没错,那个保留在那里,因为它是gradle本身的插件,而不是你的应用程序。 - Ian Barber

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接