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