手机
当前位置:查字典教程网 >编程开发 >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通过接口实现匿名类的实例代码

各种格式的编码解码工具类分享(hex解码 base64编码)

java文件操作工具类分享(file文件工具类)

java字符串反转示例分享

通过代理类实现java连接数据库(使用dao层操作数据)实例分享

精品推荐
分类导航