From 88f0e4abe8919b0f793911a01550e3bd7cb349a7 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期三, 28 十二月 2022 09:26:45 +0800
Subject: [PATCH] #
---
src/main/java/com/zy/core/News.java | 41 +++++++++++++++++++++++++++++++++--------
1 files changed, 33 insertions(+), 8 deletions(-)
diff --git a/src/main/java/com/zy/core/News.java b/src/main/java/com/zy/core/News.java
index 47b3c24..3d51fa7 100644
--- a/src/main/java/com/zy/core/News.java
+++ b/src/main/java/com/zy/core/News.java
@@ -1,9 +1,9 @@
package com.zy.core;
-import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;
import java.lang.reflect.Array;
+import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
@@ -19,7 +19,7 @@
News.info("info{}", 1);
News.warn("warn{}", 2);
News.error("error{}", 3);
- System.out.println(JSON.toJSONString(NEWS_QUEUE.data()));
+ System.out.println(News.print());
}
interface NewsSupport<T> { boolean execute(T t); }
@@ -97,19 +97,40 @@
}
public static void info(String format, Object... arguments) {
+ log.info(format, arguments);
offer(NewsLevel.INFO, format, arguments);
}
public static void warn(String format, Object... arguments) {
+ log.warn(format, arguments);
offer(NewsLevel.WARN, format, arguments);
}
public static void error(String format, Object... arguments) {
+ log.error(format, arguments);
offer(NewsLevel.ERROR, format, arguments);
}
+ public static String print() {
+ StringBuilder sb = new StringBuilder("[");
+ List<NewsDomain> domains = NEWS_QUEUE.data();
+ for (int i = 0; i < domains.size(); i++) {
+ NewsDomain domain = domains.get(i);
+ sb.append("{");
+ sb.append("\"l\":").append(domain.level.idx).append(",");
+ sb.append("\"v\":\"").append(domain.content).append("\"").append(",");
+ sb.append("\"t\":\"").append(domain.date).append("\"");
+ sb.append("}");
+ if (i < domains.size() - 1) {
+ sb.append(",");
+ }
+ }
+ sb.append("]");
+ return sb.toString();
+ }
+
private static boolean offer(NewsLevel level, String msg, Object[] args) {
- return NEWS_QUEUE.offer(new NewsDomain(level, replace(msg, args), new Date()));
+ return NEWS_QUEUE.offer(new NewsDomain(level, replace(msg, args), (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")).format(new Date())));
}
private static String replace(String str, Object[] objs){
@@ -129,9 +150,9 @@
static class NewsDomain {
public NewsLevel level;
public String content;
- public Date date;
+ public String date;
- public NewsDomain(NewsLevel level, String content, Date date) {
+ public NewsDomain(NewsLevel level, String content, String date) {
this.level = level;
this.content = content;
this.date = date;
@@ -139,10 +160,14 @@
}
enum NewsLevel {
- INFO,
- WARN,
- ERROR,
+ INFO(1),
+ WARN(2),
+ ERROR(3),
;
+ public int idx;
+ NewsLevel(int idx) {
+ this.idx = idx;
+ }
}
}
--
Gitblit v1.9.1