mac
2024-01-05 51d7007fd4bcaaa771d43a745cb6728d4e6d29ae
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
package com.hdl.photovoltaic.other;
 
 
import com.hdl.photovoltaic.utils.TimeUtils;
 
/**
 * 日志逻辑
 */
public class HdlLogLogic {
 
    //是否需要打印到Logcat上(true不需要打印)
    public static boolean isPrintLogcat = false;
    //默认打印标题
    private static final String title = "自定义输出打印信息:";
 
 
    /**
     * java打印
     *
     * @param content 自定义信息描述
     *                默认不加入本地日志
     */
    public static void print(String content) {
        printBase(content, "0", false);
    }
 
    /**
     * java打印
     *
     * @param content   自定义信息描述
     * @param isBoolean 是否加入内存(本地日志用到)
     */
    public static void print(String content, boolean isBoolean) {
        printBase(content, "0", isBoolean);
    }
 
    /**
     * java打印
     *
     * @param msg       自定义信息描述
     * @param code      状态码
     * @param isBoolean 是否加入内存(本地日志用到)
     */
    public static void print(String msg, int code, boolean isBoolean) {
        printBase(msg, code + "", isBoolean);
    }
 
 
    /**
     * java打印和存储日志
     *
     * @param msg       信息描述
     * @param code      状态
     * @param isBoolean 是否加入内存(本地日志用到)
     */
    private static void printBase(String msg, String code, boolean isBoolean) {
        if (isPrintLogcat) {
            return;
        }
        CustomLogObject customLogObject = new CustomLogObject();
        customLogObject.msgOrData = msg;
        customLogObject.code = code;
        String json = title;
        json += customLogObject.getJointMessage();
        System.out.println(json);
        if (isBoolean) {
            writeLog(customLogObject.getJointMessage());
        }
    }
 
 
    /**
     * 写入日志内容到本地
     *
     * @param strLog 写入内容
     */
    public static void writeLog(String strLog) {
        synchronized (HdlLogLogic.class) {
            strLog = TimeUtils.getTimeFromTimestamp(System.currentTimeMillis()) + "s%" + " " + strLog;//加打印时间(s%占位符,设置显示时间不同字体颜色)
            HdlFileLogic.getInstance().appendFile(HdlFileLogic.getInstance().getLogFileNamePath(), strLog);
        }
    }
 
    /**
     * 读取日志内容
     *
     * @return 日志内容
     */
    public static String readLog() {
        return HdlFileLogic.getInstance().readFile(HdlFileLogic.getInstance().getLogFileNamePath());
    }
 
 
    /**
     * 自定义日志类
     */
    static class CustomLogObject {
        //信息描述
        public String msgOrData = "";
        //状态码
        public String code = "0";
 
        public String getJointMessage() {
 
            if ("0".equals(code)) {
                return msgOrData;
            }
            return msgOrData + "(" + code + ")";
 
        }
    }
 
 
}