工厂方法简单例子


package test.factorymethod;

/**
* 控制台日志
*/
public class ConsoleLogger implements Logger
{

public void log(String msg) {
System.out.println(msg);

}

}



package test.factorymethod;

/**
* 文件日志
*/
public class FileLogger implements Logger
{

public void log(String msg) {

FileUtil futil = new FileUtil();
futil.writeToFile("log.txt", msg);
}

}



package test.factorymethod;

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));
out.write(message);
out.close();
}
catch (IOException e)
{
e.printStackTrace();
}

}
}




package test.factorymethod;

/**
* 日志接口
*
*/
public interface Logger {

/**
* 日志方法
* @param msg
*/
public void log(String msg);
}




package test.factorymethod;

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

/**
* 日志工厂类
*/
public class LoggerFactory {
/**
* 文件日志是否启用
* @return
*/
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 new FileLogger();
}
else
{
return new ConsoleLogger();
}
}
}




package test.factorymethod;

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


FileLogging=ON
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值