单例模式简单例子


package test.singleton;

/**
* 文件日志类
*
*/
public class FileLogger implements Logger
{
private static FileLogger logger;

private FileLogger()
{

}

public static FileLogger getFileLogger()
{
if(logger==null)
{
logger = new FileLogger();
}
return logger;

}
public synchronized void log(String msg) {
FileUtil futil = new FileUtil();
futil.writeToFile("log.txt", msg);
}

}




package test.singleton;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;

public class FileUtil
{
/**
* 写文件
* @param fileName
* @param message
*/
public void writeToFile(String fileName,String message)
{
try
{
BufferedWriter out = new BufferedWriter(new FileWriter(fileName,true));
out.write(message);
out.write("\n");
out.close();
}
catch (IOException e)
{
e.printStackTrace();
}

}
}




package test.singleton;

/**
* 日志接口
*
*/
public interface Logger {
/**
* 日志方法
* @param msg
*/
public void log(String msg);
}




package test.singleton;

import java.io.IOException;
import java.util.Properties;

/**
* 日志工厂类
*/
public class LoggerFactory {
/**
* 文件日志是否启用
* @return true:启用 false:未启用
*/
public boolean isFileLoggingEnabled()
{

Properties p = new Properties();
try
{
p.load(ClassLoader.getSystemResourceAsStream("logger.properties"));
String fileLoggingValue = p.getProperty("FileLogging");
if(fileLoggingValue.equalsIgnoreCase("ON")==true)
{
return true;
}
else
{
return false;
}
}
catch (IOException e) {
return false;
}
}

/**
*
* @return
*/
public Logger getLogger()
{
if(isFileLoggingEnabled())
{
return FileLogger.getFileLogger();
}
return null;

}
}



package test.singleton;

public class LoggerTest {
public static void main(String[] args)
{
LoggerFactory factory = new LoggerFactory();
Logger logger = factory.getLogger();
logger.log("Test Message to Log1");
logger.log("Test Message to Log2");
logger.log("Test Message to Log3");
}
}



FileLogging=ON
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值