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

article/2025/9/27 8:49:18

文章目录

  • 1 带分割线版
  • 2 不带分割线版
  • 3 终极版


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);}}

http://chatgpt.dhexx.cn/article/qjZpaA64.shtml

相关文章

Java 对象拷贝工具类

目录 1. Spring 中的对象拷贝 2. 本工具类中的对象拷贝 2.1 拷贝对象本身(单个) 2.2 拷贝对象本身(批量) 2.3 拷贝对象属性至其他类(单个) 2.4 拷贝对象属性至其他类(批量) 4.…

Java表达式运算工具类

对于表达式的运算转换工具类,使用场景,例如前端文本框让用户输入了加减乘除运算,工具类智能转换。 资源下载:Java表达式工具类,用于加减乘除等智能转换-Java文档类资源-CSDN下载 例如: public static void…

阿里OSS工具类

参考博客:阿里OSS入门 bucket配置信息:alios.properties OSS配置文件:AliOSSConfig.java Data public class AliOSSConfig {private String endpoint;private String accessKeyId;private String accessKeySecret;private String bucketNam…

Guava Lists工具类

文章目录 01 概述02 Lists工具类03 文末 01 概述 Guava 是 Google 开源的一个 Java 工具库&#xff0c;里面有很多工具类&#xff0c;本文要讲的是里面的Lists工具类。 注意&#xff0c;使用Guava工具类库&#xff0c;必须先添加依赖&#xff1a; <dependency><gro…

JAVA之常用的工具类

目录 1 集合工具类 1.1 java.util.Collections 1.1.1 基本操作 1.1.2 转换线程安全集合 1.2 org.springframework.util.CollectionUtils 1.3 org.apache.commons.collections.CollectionUtils 1.4 org.apache.commons.lang.ArrayUtils 1.5 org.apache.commons.lang3.Ar…

常用的Java开发工具类

前言 在java的庞大体系中&#xff0c;其实有很多不错的小工具&#xff0c;也就是我们平常说的&#xff1a;轮子。 如果在我们的日常工作当中&#xff0c;能够将这些轮子用户&#xff0c;再配合一下idea的快捷键&#xff0c;可以极大得提升我们的开发效率。 今天我决定把一些…

工具类的详解

工具类网站 1、工具类 1.1 定义 工具类是为了提供一些通用的、某一非业务领域内的公共方法&#xff0c;不需要配套的成员变量&#xff0c;仅仅是作为工具方法被使用。所以将它做成静态方法最合适&#xff0c;不需要实例化&#xff0c;能够获取到方法的定义并调用就行。 1.2…

学习日记-安卓Package Manager和Package Installer

安装和卸载APK&#xff08;安卓应用程序包文件&#xff09;&#xff0c;运作原理。 什么是Package Manager&#xff08;包管理器&#xff09;和Package Installer&#xff08;程序安装包&#xff09;&#xff1f; APK文件保存在Android的哪个地方&#xff1f; APK文件安装过…

PackageInstaller (tv 修改安装app界面按钮及自动获取焦点)附源码分析

\packages\apps\PackageInstaller 一、一条真实的修改记录 TVOS基于的是一套板卡厂商原有的源码(mstar android8.0版本&#xff09;原生的这个app安装界面&#xff0c;存在俩个比较严重的用户体验问题&#xff0c; 1’、下面那俩按钮太小了&#xff0c;而且…

android packages/apps 加入工程,深入安卓Package Manager和Package Installer

我们每天都在安装和卸载APK(安卓应用程序包文件)&#xff0c;或许一天会有好几次&#xff0c;但是你有想过下面问题吗&#xff1f;什么是Package Manager(包管理器)和Package Installer(程序安装包)&#xff1f; APK文件保存在Android的哪个地方&#xff1f; APK文件安装过程的…

RK3568平台开发系列讲解(安卓篇)PackageInstaller(应用安装)流程介绍

文章目录 <font color=#0990d9>一、PackageInstaller入口<font color=#0990d9>二、InstallStart<font color=#0990d9>三、InstallStaging<font color=#0990d9>四、PackageInstallerActivity<font color=#0990d9>五、InstallInstalling<font c…

Android9.0 PM机制系列(一)PackageInstaller初始化解析

前言 包管理机制是Android中的重要机制&#xff0c;是应用开发和系统开发需要掌握的知识点之一。 包指的是Apk、jar和so文件等等&#xff0c;它们被加载到Android内存中&#xff0c;由一个包转变成可执行的代码&#xff0c;这就需要一个机制来进行包的加载、解析、管理等操作&…

PackageInstaller源码分析(一)

本篇博客分析PackageInstaller源码目的是分析Android权限机制&#xff0c;Android App的权限在应用被安装时&#xff0c;用户选择授予或者拒绝。所以&#xff0c;分析Android权限机制源码的第一步分析应用程序安装时的行为。   此次阅读源码旨在解决的问题&#xff1a;Andro…

A*B problem(FFT)

A*B problem&#xff08;FFT&#xff09; 设两个多项式\(A(x)\)和\(B(x)\)&#xff0c;它们的系数镜像反转一下&#xff0c;得到的多项式是\(A(x)\)和\(B(x)\)。那么\(C(x)A(x)*B(x)\)和\(C(x)A(x)*B(x)\)的系数也是镜像反转的。这个&#xff0c;&#xff0c;感性理解一下吧。 …

【kissfft】使用过程中的一些坑总结

API kissfft有两套API&#xff0c; 一个是在kiss_fftr.h中 另一个在kiss_fft.h中 区别 Basic API还是kiss_fft.h里的&#xff0c;kiss_fftr.h是在kiss_fft.h的基础上封装了一层。 Basic API只有fft没有见到ifft&#xff1f;&#xff1f; 利用频域数据的共轭对称性可以使用…

2020山东大学计算机组成原理课程设计报告

《计算机组成原理》 课程设计报告 微指令模型机实现 班级&#xff1a; 姓名&#xff1a; 学号&#xff1a; 小组成员&#xff1a; 完成日期&#xff1a;2020.10.16 一、计算机的功能和用途 通过该课程设计的学习&#xff0c;我们设计一台模型机&#xff0c;该模型机运行…

创建react应用程序_创建多版本React应用程序的6个步骤

创建react应用程序 The React team said that there are no new features in React 17, but react17.0.0-rc.0 comes with the power to lazy load and deep integrate multiple versions of React. This no-feature is larger than any feature, which is a stepping stone fo…

你真的懂package.json吗

点击蓝字 「前端小苑」关注我 作者 | MasonEast 编辑 | 桔子酱 前言 在Node.js中&#xff0c;模块是一个库或框架&#xff0c;也是一个Node.js项目。Node.js项目遵循模块化的架构&#xff0c;当我们创建了一个Node.js项目&#xff0c;意味着创建了一个模块&#xff0c;这个模块…

《Linux编程》上机作业 ·004【文件I/O操作】

注&#xff1a;前言、目录见 https://blog.csdn.net/qq_44220418/article/details/108428971 友情提醒&#xff1a;仅供参考理解&#xff0c;请勿直接复制粘贴 友情提醒&#xff1a;仅供参考理解&#xff0c;请勿直接复制粘贴 友情提醒&#xff1a;仅供参考理解&#xff0c;…

CPU比GPU训练神经网络快十几倍,英特尔:别用矩阵运算了

来源丨机器之心 神经网络训练通常是 GPU 大显身手的领域&#xff0c;然而莱斯大学和英特尔等机构对 GPU 的地位发起了挑战。 在深度学习与神经网络领域&#xff0c;研究人员通常离不开 GPU。得益于 GPU 极高内存带宽和较多核心数&#xff0c;研究人员可以更快地获得模型训练的结…