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>
相关推荐
无风之翼7 分钟前
android12下拉菜单栏界面上方显示无内容
android·java
6***941514 分钟前
MySQL 字符串日期格式转换
android·数据库·mysql
p***q7816 分钟前
MySQL——用户管理
android·mysql·adb
g***866922 分钟前
MySQL - Navicat自动备份MySQL数据
android·数据库·mysql
q***017728 分钟前
【MySQL】数据类型
android·数据库·mysql
大数据女孩_Aimee37 分钟前
AndroidAutoOverUsbInteractiveHostTest FAIL
android·测试用例
c***87191 小时前
Tomcat10下载安装教程
android·前端·后端
hqk1 小时前
鸿蒙 ArkUI 从零到精通:基础语法全解析
android·前端·harmonyos
5***g2982 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
牛奔2 小时前
php 8.2 配置安装php-zbarcode扩展
android·开发语言·php