android bindService打开失败

在写demo验证SurfaceControlViewHost的时候,bindService提示

Unable to start service Intent U=0: not found

在源代码里搜了下,找到是在如下方法里面里面打印出来的

java 复制代码
// frameworks/base/services/core/java/com/android/server/am/ActiveServices.java
retrieveServiceLocked {
    ....
    if(mAm.getPackageManagerInternal().filterAppAccess(r.packageName,callingUid,
        userId)){
        Slog.w(TAG_SERVICE,"Unable to start service "+service+" U="+userId
        +": not found");
        returnnull;
    }
    ....
}

后面查了下,发现是包可见性的变更引起的异常

Android 11 中的软件包可见性 | Android Developers
Android 上的软件包可见性过滤 | Android Developers

解决方案,在使用的bindService的应用的AndroidManifest.xml里面加上queries,类似如下

java 复制代码
    <queries>
        <package android:name="com.example.host"/>
    </queries>
相关推荐
apigfly1 小时前
深入Android系统(十三)Android的窗口系统
android·设计模式·源码
k***85841 小时前
【SpringBoot】【log】 自定义logback日志配置
android·前端·后端
S***q1921 小时前
Kotlin内联函数优化
android·开发语言·kotlin
小墙程序员1 小时前
在Android中,kotlin 的一些开发技巧(二)
android·kotlin
曾经的三心草2 小时前
JavaEE初阶-多线程1
android·java·java-ee
q***73553 小时前
windows配置永久路由
android·前端·后端
m***9823 小时前
万字详解 MySQL MGR 高可用集群搭建
android·mysql·adb
u***u6853 小时前
Kotlin多平台开发实践
android·开发语言·kotlin
Digitally3 小时前
如何将照片从安卓手机传输到电脑?
android·智能手机·电脑
打工人你好3 小时前
Android 应用逆向分析与架构研究笔记
android·笔记·架构