android log格式,Android 好用Log日志库分享

这是一个Android 上 效率极高的 Log 工具,主要功能为控制不同级别的Log输出,Log信息保存到文件、打印行号、函数调用、Json解析、点击跳转、多标签Tag 支持无限长字符串打印,无Logcat4000字符限制等功能

打印行号、函数调用、Json解析、点击跳转 参照KLog of ZhaoKaiQiang.

Gradle

dependencies {

implementation 'com.github.iflove:Logcat:v2.0.0'

}

1.开始使用 Logcat

你只需要在 Application 里面调用Logcat.initialize一次即可完成初始化

//初始化Logcat

Logcat.initialize(this);

配置更多信息

Builder builder = Logcat.newBuilder();

builder.topLevelTag("Root");

//设置Log 保存的文件夹

builder.logSavePath(StorageUtils.getDiskCacheDir(this, "log"));

//设置输出日志等级

if (BuildConfig.DEBUG) {

builder.logCatLogLevel(Logcat.SHOW_ALL_LOG);

} else {

builder.logCatLogLevel(Logcat.SHOW_INFO_LOG | Logcat.SHOW_WARN_LOG | Logcat.SHOW_ERROR_LOG);

}

//设置输出文件日志等级

builder.fileLogLevel(Logcat.NOT_SHOW_LOG);

Logcat.initialize(this, builder.build());

2.示例

//控制台

Logcat.v("The is verbose log");

Logcat.d("The is debug log");

Logcat.i("The is info log");

Logcat.w("The is warn log");

Logcat.e("The is error log");

3.LogTransaction 为Logcat 提供灵活的链式调用api

msg(@NonNull final Object msg);// 打印 msg

msgs(@NonNull final Object... msg);// n ... msg

tag(@NonNull final String tag);// 打印 tag

tags(@NonNull final String... tags); //n ... tag

file(); // log默认输出到文件

file(@NonNull final String fileName); //指定文件名

ln(); //换行

format(@NonNull final String format, Object... args); //格式化

out(); //输出log

4.Logcat log 文件

--默认log文件夹 sdcard/Android/data/you.pakeage/cache/logs 下

//文件log 格式

11-29 22:25:32.363 5523-1/com.lazy.logging V/Logcat[ (MainActivity.java:104)#PrintLog ] output file msg

5.JLog

安卓开发者都知道,Android系统的单条日志打印长度是有限的, 底层Logger Logger.h 文件中限制了输出日志字符的大小,具体原因就不造了。

Logger.h

#define LOGGER_ENTRY_MAX_LEN (4*1024)

#define LOGGER_ENTRY_MAX_PAYLOAD \\

(LOGGER_ENTRY_MAX_LEN - sizeof(struct logger_entry))

开发也没法子通过API来改变这一值。只能采取分段打印的办法输出日志信息。但是我发现了Java 的System.out.println() 是没有限制的,但是在安卓平台上这会转变为安卓INFO 级的日志,而且无需你分段打印的输出日志(是不是很😑)。在实际项目中,一般就也只有请求HTTP接口,而接口又是返回一个比较大JSON,超过4000 字符,安卓的Log API 就好截断,就无法看到完整的响应数据了。采取分段输出,虽然能看到完整的响应数据,但是每达4000字符时突然的换行以及不对齐,稍微不慎就会拷错,拷多json 字符串处理用工具解析查看。当然每次调试看请求数据也是可以的不过很是低效的。所以我做了个大胆的尝试(加入JLog),通过 socket 把日志传送到Java的控制中打印。

JLogServer

Run JLogServer 步骤: 下载JLogServer.java 到你的项目,用as 直接run main(),JLogServer 可以配置相应的端口,也可以用adb 端口映射。

d9cce91df5ce

20181129-0.png

Logcat dispatchLog

...

builder.dispatchLog(new JLog("192.168.3.15", 5036));

6.Future

JLogServer.java 是否能作为一个idea intellij plugin ?

7.Sample Usage

d9cce91df5ce

ScreenShot-2017-12-05.png

超长的Log完美输出

d9cce91df5ce

20181129-1.png

json format 输出格式

d9cce91df5ce

Jietu20181129-223652.jpg

文件Log输出格式

d9cce91df5ce

20181129-3.png

License

Copyright 2016 Lazy

Licensed under the Apache License, Version 2.0 (the "License");

you may not use this file except in compliance with the License.

You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software

distributed under the License is distributed on an "AS IS" BASIS,

WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

See the License for the specific language governing permissions and

limitations under the License.

欢迎扫一扫!

d9cce91df5ce

11547476583_.pic.jpg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值