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

}
目录
相关文章
|
2月前
|
Java 开发者
在 Java 中,一个类可以实现多个接口吗?
这是 Java 面向对象编程的一个重要特性,它提供了极大的灵活性和扩展性。
160 57
|
11天前
|
JSON Java Apache
Java基础-常用API-Object类
继承是面向对象编程的重要特性,允许从已有类派生新类。Java采用单继承机制,默认所有类继承自Object类。Object类提供了多个常用方法,如`clone()`用于复制对象,`equals()`判断对象是否相等,`hashCode()`计算哈希码,`toString()`返回对象的字符串表示,`wait()`、`notify()`和`notifyAll()`用于线程同步,`finalize()`在对象被垃圾回收时调用。掌握这些方法有助于更好地理解和使用Java中的对象行为。
|
2月前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
65 8
|
2月前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
76 17
|
2月前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
2月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
137 4
|
2月前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
84 2
|
2月前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
67 4
|
2月前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
55 5
|
2月前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
117 5