Android 日志框架使用

news2024/11/17 5:22:07

 在实际开发中,经常会遇到需要打印日志并保存到文件中,便于后面取日志分析代码运行情况,当然如果只是打印日志不需要记录文件,使用android自带的log工具就完全够了,

Log打印日志会记录到系统日志中,可以取出系统日志然后通过tag过滤得到自己的log,不过系统日志比较大,一般只能保存一段时间的日志,所以我们需要把日志单独记录到自己的文件中,这样就不会被系统日志冲掉了。

1、使用到的开源日志框架有以下两个,可以网上自己下载, 也可以通过以下链接下载https://download.csdn.net/download/x995630736/87719297

android-logging-log4j-1.0.3.jar
apache-logging-log4j.jar

2、创建android 工程,jatr包放到libs目录下,并build.gradle中增加下面两行,重新编译

implementation files('libs/android-logging-log4j-1.0.3.jar')
implementation files('libs/apache-logging-log4j.jar')

3、创建自己的日志文件路径和文件名,我的日志路径如下,会在sdcard目录下生产LOG目录,

 public static String LOG_PATH = Environment.getExternalStorageDirectory().getAbsolutePath() + "/LOG/;

public static String appFile = "";

File file = new File(FileConfig.LOG_PATH );
if (!file.exists()) {
   file.mkdirs();
}
if (appFile == null || appFile.isEmpty()) {
   appFile = "app-" + getDateToStringStyle("yyyy-MM-dd-HH-mm", new Date()) + ".txt";
}

getDateToStringStyle是根本一定格式获取当前时间,方便看日志是什么时候生成的

 

4、配置日志参数, 可以放在MyApplication中初始化,这样在整个app中都可以调用

private static Logger logger = null;
LogConfigurator logConfigurator = new LogConfigurator();
logConfigurator.setFileName(FileConfig.LOG_PATH + appFile);
logConfigurator.setRootLevel(Level.WARN);
logConfigurator.setLevel("TEST", Level.WARN);
logConfigurator.setFilePattern("%m%n");
logConfigurator.setMaxFileSize(1024 * 1024 * 10);
logConfigurator.setImmediateFlush(true);
logConfigurator.configure();
logger = Logger.getLogger("TEST");

5、写日志到文件中

public static void logInfo(final Object msg) {
    if (msg == null || msg.toString().isEmpty()) {
        return;
    }
    String appMsg = getDateToStringStyle("MM-dd HH:mm:ss,SSS", new Date()) + ":" + msg.toString();
    if (logger == null) {
        logger = Logger.getLogger("TEST");
    }
    logger.warn(appMsg);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/452128.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

光敏电阻传感器模块资料

实物项目案例 实物图: PCB图: 原理图: 用途: 光线亮度检测,光线亮度传感器,智能小车寻光模块 模块特色: 1、采用灵敏型光敏电阻传感器 2、比较器输出,信号干净,波形好&#x…

【Leetcode】10. 正则表达式匹配

10. 正则表达式匹配(困难) 题解 如果从左向右进行匹配的话,需要考虑字符后是否有 * 。 因此选择从右向左扫描更为简单。 *前面肯定有一个字符,它像是一个拷贝器,能够复制前面的单个字符,甚至也可以把这个…

Java 1.8新特性

接口的默认方法 Java 8允许给接口添加一个非抽象的方法实现,只需要使用default关键字即可,这个特征又叫做扩展方法 interface Formula {double calculate(int a);default double sqrt(int a) {return Math.sqrt(a);} }Formula接口在拥有calculate方法之…

【Linux初阶】进程的相关概念 | 进程管理 查看进程 获取进程标识符 fork进程创建

🌟hello,各位读者大大们你们好呀🌟 🍭🍭系列专栏:【Linux初阶】 ✒️✒️本篇内容:进程的概念,进程管理初识(描述、管理进程),查看进程的基础方法…

【Nav2】ROS2 Eloquent中使用robot_state_publisher发布松灵Scout mini的urdf

【背景】 本来打算把ROS1版本的松灵Scout mini 模型描述文件直接移植到ROS2的工作空间里去,用robot_state_publisher加载出来,结果行不通;于是找到了ROS2版本的Scout mini 模型描述,结果因为我用的是 Eloquent 版本,而…

MobTech MobPush|A/B测试提升运营决策

在实际推送过程中,我们常常有这样的困惑: 我们如何确定哪种推送内容更能吸引用户? 我们如何衡量推送效果的提升程度? 我们如何优化推送方案,实现更高的ROI? 为了解决这些困惑,我们需要一种科…

碳中和成“必答题”,宁德时代创造产业“零碳”新维度

文 | 智能相对论 作者 | leo陈 2021年,麻省理工学院的教授索尔格里菲斯出版了《零碳未来》一书,这本著作总结了数十年的研究经验和数据,紧迫地提出,我们需要可以利用现有技术和资源快速应对气候变化的“零碳行动方案”。 既要保…

Netty时间轮源码解析

Netty主要应用用于网络通信,Netty还有一个非常重要的应用领域,即时通信系统IM, 在IM聊天系统中,有成千上万条条链路, Netty是如何管理这些链路的呢 ? Netty还有一套自带的心跳检测机制,这套检测机制的原理是…

HCIP-7.0华为交换机技术基础学习

交换机基础 1、交换机工作原理1.1、VLAN虚拟局域网1.1.1、VLAN帧格式1.1.2、VLAN的划分方式:1.1.3、PVID1.1.4、Access端口类型1.1.5、Trunk端口类型1.1.6、Hybird端口类型 1.2、MUX VLAN应用场景和原理1.2.1、MUX VLAN原理1.2.2、MUX VLAN配置 1、交换机工作原理 …

软件测试—用例篇(上)

软件测试—用例篇 🔎测试用例的概念🔎测试用例的好处🔎测试用例的设计方法🌸基于需求的设计方法🌸等价类划分法🌸边界值分析法🌸判定表 🔎结尾 🔎测试用例的概念 为了实…

【Python】如何用pyth做游戏脚本(太简单了吧)

文章目录 前言一、开发前景二、开发流程3.1、获取窗口句柄,把窗口置顶3. 2、截取游戏界面,分割图标,图片比较 二、程序核心-图标连接算法(路径寻找)四、开发总结五、源码总结 前言 简述:本文将以4399小游戏…

使用@Import注解给容器中快速导入一个组件

注册bean的方式 向Spring容器中注册bean通常有以下几种方式: 包扫描给组件标注注解(Controller、Servcie、Repository、Component),但这种方式比较有局限性,局限于我们自己写的类Bean注解,通常用于导入第…

软测如果这么学,培训班都得倒闭,直接省去上万元的学费

俗话说外行看热闹,内行看门道。 写这篇文章,是希望把我的一些我认为是非常有价值的经验总结出来,能够帮助刚做测试不久的新同学,或者是测试经验丰富的老同学以共享。 希望我们可爱的新同学,准备要在测试领域耕耘的伙…

Git推出大文件储存工具Git LFS,但它真的好用吗?

Git LFS(全称为Git Large File Storage,Git大文件存储)被许多团队用来管理和存储大文件。本篇文章将解释Git LFS是什么,它的功能和使用场景,以及它究竟是不是管理大文件的最佳版本控制工具。 什么是Git LFS&#xff0…

共治、共建、共享!龙蜥社区第 16 次运营委员会会议顺利召开!

4 月 14 日,龙蜥社区在凝思软件召开了第 16 次运营委员会会议,本次会议由统信软件运营委员会委员崔开主持。来自阿里云、红旗软件、海光、Intel、联通软研院、浪潮信息、凝思软件、普华基础软件、统信软件、万里红、新华三、中科方德等理事单位的 23 位委…

第一章 Go环境搭建

前言 Golang是一种比较新颖的编程语言,其强大的功能以及底层的强大支撑快速的成为了编程语言的佼佼者,使其备受欢迎。 1、Go的安装与配置 如果你有一定的开发经验或者学习知识肯定知道,如何语言的开发都需要进行环境的配置与相关资源的安装…

12. 图的进阶

12. 图的进阶 12.1 有向图 在实际生活中,很多应用相关的图都是有方向性的,最直观的就是网络,可以从A页面通过链接跳转到B页面,那么a和b连接的方向是a->b,但不能说是b->a,此时我们就需要使用有向图来解决这一类问题&#x…

8 年后端开发,API 设计的学习方法分享

笔者目前在参与一个开源项目,平时接触多的也是 API 相关的核心功能开发,经常会有读者私信我,对于开发新人而言,如何快速学习 API 设计,我简单总结了一下: 1. 学习基础知识:学习HTTP、RESTful AP…

Vue表单基本操作-收集表单数据

收集表单数据 使用vue中的v-model收集表单里面的数据,不同的表单元素配合v-model会有不同的写法和技巧 本次的表单元素包括:文本框,单选,多选,下拉框,文本域 编写表单元素 首先编写表单元素,…

IT项目管理 PPT 选择题【太原理工大学】

单选题,10*2分20分 填空题,10*2分20分 判断题,10*1分10分 画图题,10分 进度计算题,15分 成本计算题,15分 简答题,5*2分10分 重点章节:3、4、5、6、7章 我觉得小题应该是在 PP…