InputContextCallback.waitForResultLocked导致的ANR

博客探讨了在Android中如何通过非阻塞异步方式获取InputConnection的Cursor CapsMode,以避免Input dispatching timeout问题。作者使用CompletableFuture进行异步处理,并在旧版本SDK中提供回退方案,确保兼容性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

InputContextCallback.waitForResultLocked

Input dispatching timed out (Waiting to send non-key event because the touched window
 has not finished processing certain input events that were delivered to it
 over 500.0ms ago. waitqueue length = 35, head.seq = 13280142,
 Wait queue head age: 5427.8ms.)			

参考资料

InputConnectionWrapper代码地址

参考ANR分析

事件处理(版本上线观察中…)

//大概的想法就是通过非阻塞异步线程返回结果
val cursorCapsMode: InputAttributes.CapsMode
    get() {
      val ic = inputConnection ?: return InputAttributes.CapsMode.NONE
    return if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.N) {
            val cf = CompletableFuture.supplyAsync<InputAttributes.CapsMode>({
                InputAttributes.CapsMode.fromFlags(
                    ic.getCursorCapsMode(inputAttributes.capsMode.toFlags())
                )
            }, newSingleThreadExecutor())
            try {
                cf.getNow(InputAttributes.CapsMode.NONE)
            } catch (e: Exception) {
                e.printStackTrace()
                cf.cancel(true)
                InputAttributes.CapsMode.NONE
            }

        } else {
            InputAttributes.CapsMode.fromFlags(
                ic.getCursorCapsMode(inputAttributes.capsMode.toFlags())
            )
        }
    }
从提供的日志来看,并没有直接显示 `com.android.systemui` 发生了 ANR(Application Not Responding)错误。然而,我们可以观察到一些可能影响系统UI性能和响应性的线索: 1. **网络问题**: - 多次出现 `DownloadThread` 停止请求并处于 `WAITING_FOR_NETWORK` 状态,这表明设备在尝试下载文件时遇到了网络连接问题。 ``` 09-27 11:44:23.822 8515 26395 W DownloadThread: [8] Stop requested with status WAITING_FOR_NETWORK: Network is disconnected ``` 2. **资源管理问题**: - 日志中多次提到 `ResourceBudgetManagerInternal is null` 和 `Power Event callback listener is empty for resId=256`,这些提示可能表示系统在处理某些资源管理和电源事件时存在问题。 ``` 09-27 11:44:22.144 2398 3321 E JobScheduler: ResourceBudgetManagerInternal is null 09-27 11:44:22.161 2398 3321 I whetstone.activity: Power Event callback listener is empty for resId=256 ``` 3. **垃圾回收**: - 系统服务器进行了大量的垃圾回收操作,释放了大量内存,这可能会导致短暂的卡顿或延迟。 ``` 09-27 11:44:22.136 2398 2411 I system_server: Background concurrent mark compact GC freed 19MB AllocSpace bytes, 11(540KB) LOS objects, 21% free, 86MB/110MB, paused 3.714ms,12.410ms total 550.919ms ``` 4. **任务调度问题**: - 日志中多次提到 `Job didn't exist in JobStore`,这可能意味着某些后台任务未能正确执行或被取消。 ``` 09-27 11:44:22.195 2398 3321 W JobScheduler: Job didn't exist in JobStore: ``` ### 综合分析 虽然日志中没有明确的 ANR 错误记录,但上述问题可能导致 `com.android.systemui` 在某些情况下响应缓慢或卡顿。特别是网络连接问题和资源管理问题,可能是导致系统UI性能下降的主要原因。建议进一步检查网络设置和系统资源管理配置,以优化系统的整体性能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值