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>
相关推荐
松叶似针1 小时前
Flutter三方库适配OpenHarmony【secure_application】— Android 端 FLAG_SECURE 实现分析
android·flutter
cjl_8520083 小时前
[MySQL] MySQL复合查询(多表查询、子查询)
android·mysql·adb
stevenzqzq3 小时前
Barrier的用法
android
城东米粉儿4 小时前
Android 窗口添加/删除流程 笔记
android
城东米粉儿4 小时前
Android Window 窗口动画原理
android
城东米粉儿4 小时前
Android Window Z轴顺序计算与窗口组织 笔记
android
城东米粉儿4 小时前
Android ActivityManagerService 笔记
android
shalou29014 小时前
mysql-connector-java 和 mysql-connector-j的区别
android·java·mysql
aaajj4 小时前
【Android】手机蜘蛛魔术的简易app例子
android
qw102484 小时前
MySQL-mysql zip安装包配置教程
android·mysql·adb