onLoadChildren 在 MediaBrowserServiceCompat 服务上发送了 id root 的空列表

Posted

技术标签:

【中文标题】onLoadChildren 在 MediaBrowserServiceCompat 服务上发送了 id root 的空列表【英文标题】:onLoadChildren sent null list for id root on MediaBrowserServiceCompat Service 【发布时间】:2017-12-13 10:57:43 【问题描述】:

每当用户尝试使用我的媒体播放器播放某些曲目时,我都会在某些设备上收到此错误。

Fatal Exception: java.lang.IllegalStateException: onLoadChildren sent null list for id root
       at android.service.media.MediaBrowserService$3.onResultSent(MediaBrowserService.java:473)
       at android.service.media.MediaBrowserService$3.onResultSent(MediaBrowserService.java:469)
       at android.service.media.MediaBrowserService$Result.sendResult(MediaBrowserService.java:131)
       at android.support.v4.media.MediaBrowserServiceCompatApi21$ResultWrapper.sendResult(MediaBrowserServiceCompatApi21.java:77)
       at android.support.v4.media.MediaBrowserServiceCompat$MediaBrowserServiceImplApi21$3.onResultSent(MediaBrowserServiceCompat.java:366)
       at android.support.v4.media.MediaBrowserServiceCompat$MediaBrowserServiceImplApi21$3.onResultSent(MediaBrowserServiceCompat.java:354)
       at android.support.v4.media.MediaBrowserServiceCompat$Result.sendResult(MediaBrowserServiceCompat.java:606)
       at com.radioafrica.music.playback.MusicPlaybackService.onLoadChildren(MusicPlaybackService.java:102)
       at android.support.v4.media.MediaBrowserServiceCompat$MediaBrowserServiceImplApi21.onLoadChildren(MediaBrowserServiceCompat.java:374)
       at android.support.v4.media.MediaBrowserServiceCompatApi21$MediaBrowserServiceAdaptor.onLoadChildren(MediaBrowserServiceCompatApi21.java:128)
       at android.service.media.MediaBrowserService.performLoadChildren(MediaBrowserService.java:495)
       at android.service.media.MediaBrowserService.addSubscription(MediaBrowserService.java:459)
       at android.service.media.MediaBrowserService.access$400(MediaBrowserService.java:68)
       at android.service.media.MediaBrowserService$ServiceBinder$3.run(MediaBrowserService.java:247)
       at android.os.Handler.handleCallback(Handler.java:739)
       at android.os.Handler.dispatchMessage(Handler.java:95)
       at android.os.Looper.loop(Looper.java:148)
       at android.app.ActivityThread.main(ActivityThread.java:7325)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

onLoadChildren 方法的代码是:

 @Override
    public void onLoadChildren(@NonNull String s, @NonNull Result<List<MediaBrowserCompat.MediaItem>> result) 
        result.sendResult(null);
    

是什么导致这对某些用户失败而对其他用户起作用?

【问题讨论】:

【参考方案1】:

我意识到这是一个较老的问题,但我最近遇到了这个问题并想留下一个答案。

这取决于您在 onGetRoot 中作为浏览器根发送的内容。我正在关注这个documentation for controlling connections with onGetRoot,它建议为具有媒体控制但没有浏览访问权限的客户端设置一个单独的空根。当请求该根时,您需要发送一个空列表,而不是 null。根据MediaBrowserService.onLoadChildren 的文档,为无效的媒体 ID 保留 Null

据我所知,pre-N 设备无法正确处理 null 值。 Here is the source code for the exception you see on Android M。请注意,发送空列表会触发此异常。由于较新的蓝牙堆栈支持媒体浏览,蓝牙包可能会尝试连接到您的服务(有很多三星设备,如 Galaxy Note 4 支持蓝牙浏览并且运行 Android M,这会在此处崩溃)。

【讨论】:

【参考方案2】:

从this issue on the tracker 的一位 Google 员工那里得到以下答复:

...这是 N 之后的固定问题,对于 N 之前的设备,如果浏览器和浏览器服务应用程序都使用支持库,则不应发生。

【讨论】:

【参考方案3】:

我替换

result.sendResult(null);

 result.sendResult(Collections.<MediaBrowserCompat.MediaItem>emptyList()); 

在 onloadChildren 方法中 为我解决了问题

【讨论】:

以上是关于onLoadChildren 在 MediaBrowserServiceCompat 服务上发送了 id root 的空列表的主要内容,如果未能解决你的问题,请参考以下文章

分配的变量引用在哪里,在堆栈中还是在堆中?

NOIP 2015 & SDOI 2016 Round1 & CTSC 2016 & SDOI2016 Round2游记

秋的潇洒在啥?在啥在啥?

上传的数据在云端的怎么查看,保存在啥位置?

在 React 应用程序中在哪里转换数据 - 在 Express 中还是在前端使用 React?

存储在 plist 中的数据在模拟器中有效,但在设备中无效