- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我知道这听起来是个懒惰的问题..但我真的不知道这种情况是如何发生的,我在谷歌上也找不到太多相关信息。
背景:
这是一个带有 IPC 的应用程序:我有一个在单独进程中运行的服务。有时,服务被杀死了……但它并没有真正“正式死亡”,相反,我从 ActivityManager
得到了一个术语,叫做“虚假死亡”。发生这种情况时,服务的行为就像僵尸一样。它还活着,但并没有真正发挥作用。
04-12 10:03:37.935 728 830 I ActivityManager: Force finishing activity ActivityRecord{11eee41f u0 com.android.staging/com.android.activities.MainActivity t8210} 04-12 10:03:37.937 728 830 I ActivityManager: Force stopping service ServiceRecord{291a4c9b u0 com.android.staging/com.android.services.CallService} 04-12 10:03:37.969 728 2563 W ActivityManager: Spurious death for ProcessRecord{27ecf545 11057:com.android.staging/u0a268}, curProc for 11057: null
最佳答案
违规行可以在这里找到: http://grepcode.com/file/repository.grepcode.com/java/ext/com.google.android/android/5.0.0_r1/com/android/server/am/ActivityManagerService.java/#4858(不同版本的Android L有不同的线路)
我假设您使用的是某种形式的 Android L,因为直到那时才添加特定的错误消息。
如果您在进程中运行 ContentProvider,ActivityManagerService 中的这两条注释可能会有所帮助:
9303 // NOTE: there is still a race here where a signal could be
9304 // pending on the process even though we managed to update its
9305 // adj level. Not sure what to do about this, but at least
9306 // the race is now smaller.
9307 if (!success) {
9308 // Uh oh... it looks like the provider's process
9309 // has been killed on us. We need to wait for a new
9310 // process to be started, and make sure its death
9311 // doesn't kill our process.
然后……
9317 appDiedLocked(cpr.proc);
appDiedLocked 也可以从其他一些源文件调用:ActiveServices.java 和 ActivityStackSupervisor.java,一个取决于抛出的 DeadObjectException,另一个取决于 RemoteException。
appDiedLocked 看起来像这样
4853 final void appDiedLocked(ProcessRecord app, int pid, IApplicationThread thread) {
4854 // First check if this ProcessRecord is actually active for the pid.
4855 synchronized (mPidsSelfLocked) {
4856 ProcessRecord curProc = mPidsSelfLocked.get(pid);
4857 if (curProc != app) {
4858 Slog.w(TAG, "Spurious death for " + app + ", curProc for " + pid + ": " + curProc);
4859 return;
4860 }
4861 }
出于某种原因,curProc 与应用程序 ProcessRecord 不同,appDiedLocked 方法被缩短了。在您的例子中,由于某种原因,curProc 为空。
长话短说:您的进程死亡或被终止,并且某些状态或条件阻止 appDiedLocked 继续运行 killProcess 命令。您需要进行更多调查/记录以查明发生这种情况的原因。
如果你有一个你想要保持活跃的服务,除非你已经在做,我建议你给它附加一个状态栏通知,这样它被杀死的可能性就会降低。
关于android - Android 中的 Spurious Death 是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29590251/
以下 latex 输入: \rule{1cm}{1cm}\\ \rule{1cm}{1cm} 在盒子之间留下大约 0.35 毫米的间隙。定义此间隙的长度是多少? 最佳答案 编辑 :起初我只是部分正确,
我有几个线程执行一些工作,然后必须进入休眠/等待不确定的时间。稍后他们都需要被叫醒并继续工作。我可以通过在对象上调用 wait() ,然后在需要恢复时在同一对象上调用 notifyall() 来实现此
当我在 eclipse 或 netbeans 中运行客户端时,我的客户端程序出现问题,出现运行时错误 java.lang.RuntimeException: Spurious Serializatio
我正在尝试使用 Apache-ant 设置 nightlybuilds。我有 apache-ant-1.8.2,带有 Java 1.6,在 openSUSE 11.4 64 位上。 我设置了一个单独的
我知道这听起来是个懒惰的问题..但我真的不知道这种情况是如何发生的,我在谷歌上也找不到太多相关信息。 背景: 这是一个带有 IPC 的应用程序:我有一个在单独进程中运行的服务。有时,服务被杀死了……但
在下面的语句中,即使没有调用通知,wait() 方法也会执行,但是 below() 语句仅在 laurel 之后执行 线程完成它的执行。 我尝试使用其他对象来锁定 hardy block 的同步,这次
我正在编写一个非常简单的 ObjC 应用程序。 (唯一的小复杂性是它使用一个名为 Chilkat 的外部库来实现一些基本网络,但我认为这不相关。) 偶尔,我的项目会自发地弹出这个警告消息: May 1
我有几个从一组中合并的观察者。由于某种原因,合并的可观察量正在调用 onComplete,即使单个可观察量没有调用。 示例: Set> set = new HashSet>(); for (O
当我尝试编译时,我收到以下警告: warning: spurious trailing ‘%’ in format [-Wformat=] warning: too many arguments fo
Java AtomicInteger 类有一个方法 - boolean weakCompareAndSet(int expect,int update) 它的文档说: May fail spuriou
我写了一个很简单的printf uint64_t的测试代码: #include #include int main() { uint64_t ui64 = 90; printf("test
我有 crate A 依赖于 B 和 B 依赖于 rust-nmea crate 。 如果我构建 crate A,我在构建 rust-nmea 期间遇到了一堆错误(所有错误都错过了 use std::
我正在阅读 CLRS,因为我遇到了这条线“然后我们可以预期虚假命中的数量是 O(n/q),因为任意 ts 的机会等于 p,模 q,可以估计为 1/q。” 我将包含完整描述的网站放在 34.2 主题下
我需要创建一个数据库补丁,将 MongoDB 集合的所有元素更新为新格式。例如,经过大大简化,旧格式的文档如下: { "_id" : ObjectId("572a7f30200cd11355083
我有一个 repo 协议(protocol),我向它添加了一个 gitattributes 并且工作正常。我通过保管箱将其同步到另一台机器。当我在另一台机器上打开它时,一堆文件突然出现在未暂存区域作为
我正在尝试在通常连接到我公司域的 Windows 10 笔记本电脑上为本地用户设置 Rust 编程环境。使用 rustup 安装稳定版本的 Rust通过 rustup-init.exe完成没有问题,但
我是一名优秀的程序员,十分优秀!