欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 美景 > Android系统通过属性设置来控制log输出的方案

Android系统通过属性设置来控制log输出的方案

2025/2/24 2:56:24 来源:https://blog.csdn.net/netwalk/article/details/140331814  浏览:    关键词:Android系统通过属性设置来控制log输出的方案

Android系统通过属性设置来控制log输出的方案

背景

       项目中经常需要在针对性的模块或者文件,分析问题的时候输出Log,但问题分析完成后,又由于性能问题,需要关闭这些log输出。当前大多数情况下是控制整个系统的log等级来实现,但这种方式会影响到其他模块,输出过多的其他模块的log,并不能使log集中于问题;这需要一种灵活的针对性的log控制方案。

方案

通过对问题模块的文件,设置特定的TAG,并关联该TAG到指定的persist属性;系统编译时默认这些属性关闭或者设置较高等级; 需要分析问题时,通过adb shell 调整这些属性;从而达到控制问题模块log输出的目的;

具体实施步骤

1、通过Log.isLoggable控制的log属性标签


例如:R基线中的AccessibilityCache.java中,TAG为:AccessibilityCache

控制的属性标签为:

log.tag.AccessibilityCache


由于该属性不能直接进行保存,所以,需要进行转接,通过persist属性进行控制

2、可以在系统中任意的rc文件中添加属性配置

这里我们选择system/core/logcat/logcatd.rc文件,在其中对log.*属性和persist.*属性进行关联

#add for log begin
on property:persist.logd.logpersistd=clearsetprop logd.logpersistd clearon property:persist.logd.logpersistd=stopsetprop logd.logpersistd stopon property:persist.log.tag.AccessibilityCache=*setprop log.tag.AccessibilityCache ${persist.log.tag.AccessibilityCache}on property:persist.log.tag.GnssLocationProvider=*setprop log.tag.GnssLocationProvider ${persist.log.tag.GnssLocationProvider}#add for log end


3、然后再在system.prop文件中对persist属性设置初始值

#for FW log.tag.*
persist.log.tag.AccessibilityCache=E
persist.log.tag.GnssLocationProvider=E
#Set logd file size 20M
persist.logd.logpersistd.rotate_kbytes=20480

4、重新编译系统

5、刷机验证

至此,编译后的版本,就可以根据需要通过以下两个属性,对AccessibilityCache.java和GnssLocationProvider.java文件中的log进行输出控制

persist.log.tag.AccessibilityCache
persist.log.tag.GnssLocationProvider

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词