在写demo验证SurfaceControlViewHost的时候,bindService提示
Unable to start service Intent U=0: not found
在源代码里搜了下,找到是在如下方法里面里面打印出来的
// 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,类似如下
<queries>
<package android:name="com.example.host"/>
</queries>