Android 服务的 onBind 未被调用,即使连接了客户端也正在调用 onDestroy

标签 android android-service

在我的应用程序中,我有一个用于播放 MP3 流音乐的服务。 我启动它 (startService()) 并连接到它 (bindService()),因此当没有客户端连接时它不会停止。 如果播放器暂停,我会在一段时间后清理一些资源,如果它继续暂停一段时间,我会清理几乎所有资源,并且:如果没有客户端连接(连接的 Activity ),我会停止调用 stopSelf() 的服务;如果有一些客户端连接,我准备销毁它,设置一个 bool 值,当所有客户端断开连接时检查,如果没有客户端连接并且这个 bool 值是真的,调用 stopSelf()。

因此,基本上,只有在 (1) 没有客户端连接到它并且 (2) 它暂停了很长时间时,服务才会被销毁。

它运行良好,但我有一个问题。在 onDestroy() 中,我释放所有资源并保存一些数据(比如正在播放的音乐列表)。如果音乐很多,可能需要将近半秒的时间。问题是当我在这段时间内再次打开我的应用程序时,onDestroy() 尚未返回。发生的情况是使用了同一个服务的实例并且没有调用 onCreate() 。所以,既然资源被释放了,自然会出现一些错误。

这个错误很难模拟。我只能复制 3 次。我不知道如何进行。我想尽可能快地从 onDestroy() 返回,使用另一个线程释放资源并保存数据,但这会使新服务在保存数据之前启动。有人知道有关在 Android 上销毁/重新创建服务的方式的更多详细信息吗?我不知道哪个类管理它,所以我不知道我可以阅读哪些代码来更好地理解它。

提前致谢。

更新:

我刚刚发现了我真正的问题。当我的 Activity 断开连接并重新连接时(当我关闭所有 Activity 并再次打开应用程序时),似乎没有调用服务的 onBind 。因此,我的资源清理器(这是计划的作业,计划在播放器暂停后的一段时间后执行)认为没有客户端连接并调用 stopSelf() (我使用 onBind 和 onUnbind 方法跟踪连接的客户端)。而且,即使有一个客户端连接到该服务,也会调用 onDestroy()。然后,我的 Activity 保持连接到刚刚清理了所有资源的服务。

我也更新了问题的标题。

更新 2:

再解释一下。当我关闭并重新打开我的应用程序时,我的 ServiceConnection 实现的 onServiceConnected 方法在 bindService 之后被调用,但服务的 onBind 没有被调用。而且它似乎真的认为没有客户端连接,因为即使文档说在所有客户端解除绑定(bind)之前启动和绑定(bind)的服务不会被破坏,它也会被破坏。

最佳答案

我发现当重新连接到服务时我的 onBind 没有被调用。所以,我开始在 onUnbind 中返回“true”。这样,当 Activity 重新连接到 Service 时,将调用 onRebind。然后,我仍然会跟踪是否有任何客户端连接,如果没有客户端连接,我的资源清理器只会调用 stopSelf。

无论如何,我认为这是一个错误。文档告诉我,在所有客户端都断开连接并调用 stopService/stopSelf 之前,同时启动 (startService()) 和绑定(bind) (bindService()) 的服务不会被销毁 (onDestroy())。因此,当我的资源清理器调用 stopSelf() 时,服务不应被销毁,因为有一个客户端已连接(当客户端重新连接时)。

关于Android 服务的 onBind 未被调用,即使连接了客户端也正在调用 onDestroy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17723614/

相关文章:

java - Android:在不影响电池生命周期的情况下将数据保存在 RAM 中

java - 具有可扩展服务的 Android 库模块

Android Activity 和 Service 的关系——暂停后、停止后

java - 来自 Activity 的 Android LiveWallpaper

java - android java中关于Thread life和AudioTrack的困惑

Android Studio lint 报告 "cannot infer argument types."

android - 弯曲画廊的可能性

java - 如何停止 Android 中另一个应用程序的服务?

android - SQLite FTS3 不一致的性能

android - 在 Mac 上的 Xamarin Studio 和 Android Studio 之间共享 Android SDK