【常用工具类】Java控制台打印工具类LogUtil

简介: 【常用工具类】Java控制台打印工具类LogUtil

@[toc]


1 带分割线版

在这里插入图片描述

import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * W SKH 的输出工具类
 */
public class LogUtil {

    private SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd,HH:mm:ss.SSS");
    private String line = "------------------------------------------------------------------------------------------------------------------------------------------------------";

    public void common(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Info-[" + simpleDateFormat.format(new Date()) + "]:" + line + "\n" + message;
            System.out.format("\033[1;29m","utf-8");
            System.out.println(str);
            after();
        }
    }

    public void info(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Info-[" + simpleDateFormat.format(new Date()) + "]:" + line + "\n" + message;
            System.out.format("\033[1;34m");
            System.out.println(str);
            after();
        }
    }

    public void error(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Error-[" + simpleDateFormat.format(new Date()) + "]:" + line + "\n" + message;
            System.out.format("\033[1;31m");
            System.out.println(str);
            after();
        }
    }

    public void success(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Success-[" + simpleDateFormat.format(new Date()) + "]:" + line + "\n" + message;
            System.out.format("\033[1;32m");
            System.out.println(str);
            after();
        }
    }

    public void warning(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Warning-[" + simpleDateFormat.format(new Date()) + "]:" + line + "\n" + message;
            System.out.format("\033[1;33m");
            System.out.println(str);
            after();
        }
    }

    public void after() {
        System.out.format("\033[0;29m");
    }

}

2 不带分割线版

在这里插入图片描述

import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * W SKH 的输出工具类
 */
public class LogUtil {

    private SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd,HH:mm:ss.SSS");

    public void common(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Common-[" + simpleDateFormat.format(new Date()) + "] : " + message;
            System.out.format("\033[1;29m","utf-8");
            System.out.println(str);
            after();
        }
    }

    public void info(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Info-[" + simpleDateFormat.format(new Date()) + "] : "+ message;
            System.out.format("\033[1;34m");
            System.out.println(str);
            after();
        }
    }

    public void error(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Error-[" + simpleDateFormat.format(new Date()) + "] : " + message;
            System.out.format("\033[1;31m");
            System.out.println(str);
            after();
        }
    }

    public void success(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Success-[" + simpleDateFormat.format(new Date()) + "] : " + message;
            System.out.format("\033[1;32m");
            System.out.println(str);
            after();
        }
    }

    public void warning(String message, boolean canBePrint) {
        if (canBePrint) {
            String str = "Warning-[" + simpleDateFormat.format(new Date()) + "] :" + message;
            System.out.format("\033[1;33m");
            System.out.println(str);
            after();
        }
    }

    public void after() {
        System.out.format("\033[0;29m");
    }

}

3 终极版

终极版取消了字体加粗,并且增加了warning和debug两种输出格式,在输出的信息中可以定位到使用LogUtil输出的语句所在位置,例如下图所示 util.TestLog.main.18(就是说在util包下的TestLog类中的main方法里,输出语句位于该类的18行)

在这里插入图片描述

import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * W SKH 的输出工具类
 */
public class LogUtil {

    protected static SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
    protected static String after = "\033[0;29m";
    public static boolean canBePrint = true;


    public static void common(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;29m");
            System.out.printf("%-8s", "COMMON");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void debug(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;35m");
            System.out.printf("%-8s", "DEBUG");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void info(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;34m");
            System.out.printf("%-8s", "INFO");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void error(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;31m");
            System.out.printf("%-8s", "ERROR");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void success(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;32m");
            System.out.printf("%-8s", "SUCCESS");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void warning(String message) {
        if (canBePrint) {
            StackTraceElement stackTraceElement = new Throwable().getStackTrace()[1];
            String classMsg = stackTraceElement.getClassName() + "." + stackTraceElement.getMethodName() + "." + stackTraceElement.getLineNumber();
            System.out.format("\033[0;33m");
            System.out.printf("%-8s", "WARNING");
            System.out.printf("%-26s", "[" + simpleDateFormat.format(new Date()) + "]");
            System.out.printf("%-1s", "[" + classMsg + "]");
            System.out.print(" : " + message + "\n");
            after();
        }
    }

    public static void after() {
        System.out.format(after);
    }

}
目录
相关文章
|
7天前
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
28 7
|
6天前
|
Java
【Java】Math、System、RunTime、BigDecimal类常用方法
【Java】Math、System、RunTime、BigDecimal类常用方法
|
4天前
|
安全 Java API
16 个最常用的 Java 实用程序类
【8月更文挑战第16天】
15 1
16 个最常用的 Java 实用程序类
|
6天前
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
11 1
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
|
7天前
|
存储 Java 数据库连接
Java类文件结构及类加载机制
该文章主要讨论了Java类文件的结构以及Java类的加载机制,并提到了双亲委派模型的相关内容。
Java类文件结构及类加载机制
|
12天前
|
存储 算法 Java
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
31 2
14 Java集合(集合框架+泛型+ArrayList类+LinkedList类+Vector类+HashSet类等)
|
2天前
|
SQL Java Apache
实时计算 Flink版操作报错合集之使用parquet时,怎么解决报错:无法访问到java.uti.Arrays$ArrayList类的私有字段
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
5天前
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
|
6天前
|
设计模式 人工智能 Java
Java 如何使用单例类
Java 如何使用单例类
5 1
|
6天前
|
前端开发 Java 编译器
【前端学java】java中的Object类和前端中的Object有什么区别(9)
【8月更文挑战第10天】java中的Object类和前端中的Object有什么区别
14 0
【前端学java】java中的Object类和前端中的Object有什么区别(9)