手机
当前位置:查字典教程网 >编程开发 >Java >自己写的简易版Java日志类分享
自己写的简易版Java日志类分享
摘要:/****/importjava.io.File;importjava.io.FileWriter;importjava.io.IOExce...

/** * */ import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; /** * @author magic282 * */ public class Logger { private static String logFilePath; private static boolean isInitialized = false; private static FileWriter logWriter = null; private static boolean printLogWhenLog = true; private static boolean InitLogger() { String logDirectoryPath = System.getProperty("user.dir") + java.io.File.separatorChar + "log"; if (!new File(logDirectoryPath).exists()) { new File(logDirectoryPath).mkdir(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); logFilePath = logDirectoryPath + java.io.File.separatorChar + dateFormat.format(logfileDate) + ".log"; try { logWriter = new FileWriter(logFilePath, true); isInitialized = true; } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Unable to create log file."); System.err.println("Initilization fail."); e.printStackTrace(); return false; } return true; } public static void Log(String message) { if (!isInitialized) { InitLogger(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); String callingClassName = new Exception().getStackTrace()[1] .getClassName(); synchronized (logWriter) { String log = String.format("[%s] @ [%s]: %sn", callingClassName, dateFormat.format(logfileDate), message); if (printLogWhenLog) { System.out.printf("[log]:%s", log); } try { logWriter.write(log); logWriter.flush(); } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Write log to file %s error."); e.printStackTrace(); } } } public static void Log(Exception exception) { if (!isInitialized) { InitLogger(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); String callingClassName = new Exception().getStackTrace()[1] .getClassName(); synchronized (logWriter) { String log = String.format("[%s] @ [%s]: %sn", callingClassName, dateFormat.format(logfileDate), exception.toString()); if (printLogWhenLog) { System.out.printf("[log]:%s", log); } try { logWriter.write(log); logWriter.flush(); } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Write log to file %s error."); e.printStackTrace(); } } } }

【自己写的简易版Java日志类分享】相关文章:

java字符串反转示例分享

Java自定义简单标签实例

java中文转全拼工具类分享

最小树形图模板朱刘算法分享

Java通过接口实现匿名类的实例代码

深入Java不可变类型的详解

java日期工具类实例分享

why在重写equals时还必须重写hashcode方法分享

Java排序实现的心得分享

深入Java对象的地址的使用分析

精品推荐
分类导航