【常用工具类】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);
    }

}
目录
相关文章
|
4月前
|
Java 编译器 API
Java 密封类:精细化控制继承关系
Java 密封类:精细化控制继承关系
338 83
|
2月前
|
安全 Java 数据建模
Java记录类:简化数据载体的新选择
Java记录类:简化数据载体的新选择
230 101
|
2月前
|
安全 Java 开发者
Java记录类:简化数据载体的新方式
Java记录类:简化数据载体的新方式
281 100
|
5月前
|
IDE Java 数据挖掘
Java 基础类从入门到精通实操指南
这份指南专注于**Java 17+**的新特性和基础类库的现代化用法,涵盖开发环境配置、数据类型增强(如文本块)、字符串与集合处理进阶、异常改进(如密封类)、IO操作及实战案例。通过具体代码示例,如CSV数据分析工具,帮助开发者掌握高效编程技巧。同时提供性能优化建议和常用第三方库推荐,适合从入门到精通的Java学习者。资源链接:[点此下载](https://pan.quark.cn/s/14fcf913bae6)。
224 36
|
3月前
|
安全 IDE Java
Java记录类型(Record):简化数据载体类
Java记录类型(Record):简化数据载体类
390 120
|
1月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
85 4
|
1月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
148 5
|
1月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
135 2
|
1月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
201 1
|
1月前
|
存储 Java 程序员
【Java】(6)全方面带你了解Java里的日期与时间内容,介绍 Calendar、GregorianCalendar、Date类
java.util 包提供了 Date 类来封装当前的日期和时间。Date 类提供两个构造函数来实例化 Date 对象。第一个构造函数使用当前日期和时间来初始化对象。Date( )第二个构造函数接收一个参数,该参数是从1970年1月1日起的毫秒数。
140 1