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>
相关推荐
哑巴湖小水怪9 小时前
Android的架构是四层还是五层
android·架构
2501_9160088911 小时前
深入解析iOS应用启动性能优化策略与实践
android·ios·性能优化·小程序·uni-app·cocoa·iphone
美狐美颜SDK开放平台12 小时前
短视频/直播双场景美颜SDK开发方案:接入、功能、架构详解
android·ios·美颜sdk·第三方美颜sdk·视频美颜sdk
untE EADO13 小时前
在 MySQL 中使用 `REPLACE` 函数
android·数据库·mysql
iblade13 小时前
Android CLI And Skills 3x faster
android
阿巴斯甜15 小时前
SharedUnPeekLiveData和UnPeekBus的区别:
android
阿巴斯甜15 小时前
UnPeek-LiveData的使用:
android
我就是马云飞15 小时前
我废了!大厂10年的我面了20家公司,面试官让我回去等通知!
android·前端·程序员
limuyang216 小时前
在 Android 上用上原生的 xxHash,性能直接拉满
android
Fate_I_C17 小时前
ViewModel 的生命周期与数据保持
android·kotlin