Android日志打印的注意事项

2019-07-22  本文已影响0人  Coder蒋

背景

在Android开发过程中难免会需要日志输出的,日志在开发调试、异常跟踪以及排查问题上都有很大的帮助,但是打印日志是一个损耗性能的动作,会占用程序执行资源,如果处理不好的话有可能会造成ANR等问题,前段时间在为公司整理基础开发库,其中涉及到日志记录库,遇到了一些坑,所以下面就日志相关的内容整理一些需要注意的关键点。

记录日志的方式

什么时候使用文件记录日志?

读写文件是一个十分消耗性能的动作,尤其是在生产环境中,因此我们应该谨慎处理需要持久化的日志,并不是所有的日志都需要持久化,我们应该将那些能够帮助我们定位问题的日志、关键数据的日志记录下来,例如:网络请求的请求体、返回值,数据库增删的操作,关键业务流程的状态日志,程序异常的错误日志等。

使用文件记录日志有哪些问题与建议?

参考示例

private static synchronized void printLog(int type, String tag, String filename, String funcname, int line, int pid, long tid, long maintid, String log) {

        if (tag == null) {
            tag = "";
        }
        if (log == null) {
            log = "";
        }
        // Android单条log长度最大值为:4*1024字节,超过的话会被Log内核驱动截断.
        // 因为String的length是字符数量不是字节数量所以为了防止中文字符过多,
        // 把4*1024的MAX字节打印长度改为1024字符数
        int maxStrLength = 1024 - tag.length();
        if (log.length() > maxStrLength) {
            //大于4000时
            while (log.length() > maxStrLength) {
                doPrintLog(type, tag, filename, funcname, line, pid, tid, maintid, log.substring(0, maxStrLength));
                log = log.substring(maxStrLength);

                if (log.length() <= maxStrLength) {
                    doPrintLog(type, tag, filename, funcname, line, pid, tid, maintid, log);
                    break;
                }
            }
        } else {

            doPrintLog(type, tag, filename, funcname, line, pid, tid, maintid, log);
        }
    }
private Object iteratorJson(Object object) {

        if (object == null) {
            return null;
        }
        if (object instanceof Map) {
            try {
                Map<String, Object> objectMap = (Map<String, Object>) object;
                Iterator<Map.Entry<String, Object>> it = objectMap.entrySet().iterator();
                while (it.hasNext()) {
                    Map.Entry<String, Object> en = it.next();
                    if(en != null) {
                        en.setValue(iteratorJson(en.getValue()));
                    }
                }
            } catch (Exception e) {

            }
        } else if (object instanceof List) {
            List<Object> objectList = (List<Object>) object;
            ListIterator<Object> iterator = objectList.listIterator();
            while (iterator.hasNext()){
                Object next = iterator.next();
                iterator.set(iteratorJson(next));
            }
        } else {
            if (object != null && object.toString() != null && object.toString().length() > SINGLE_LOG_MAX_LENGTH) {
                return "value data too long";
            }
        }
        return object;
    }

最后

目前我们已经基于Mars/XLog封装了一套自己的日志记录库,这个库在之后整理好后悔开源出来,敬请期待。

上一篇 下一篇

猜你喜欢

热点阅读