我们在开发系统应用时,如果应用之间通过广播进行交互,logcat会打印如下信息,用于告知开发者,当前行为是危险的,对外发送没有保护的广播。Sending non-protected broadcast callerPkg from system 26672:callerPkg/1000 pkg callerPkg
。如果我们没办法修改Framework
的代码,确实没办法忽略这种头疼的打印,尤其在频繁的广播交互,出现问题时非常影响定位Bug。
如果有修改Framework
的可能,可以在ActivityManagerService
类中加入下面方法。
typescript
//方法主要用于判断是否我们自己开发的系统应用,即我们要忽略上打印应内容的。
//callerPackage 发送广播的包名
//返回true表示是我们开发的系统应用,false则不是,走系统默认行为
public boolean isOurPkg(String callerPackage){
if (callerPackage!=null&&callerPackage.startsWith("cn.njdbl")){
return true;
}
return false;
}
并在ActivityManagerService
类的checkBroadcastFromSystem
方法中增加下面截图内容,就可以解决上面红色异常警告内容。 最后,欢迎访问我的Github,欢迎start、collect、comment、share。转载一定要备注本文出处哦。