结构型模式的应用(一)桥接模式

文章描述了一个使用Java编程实现的桥接模式设计,目的是创建一个数据转换工具,该工具能将数据库中的数据转换成TXT、XML、PDF等多种文件格式,并且支持多种不同的数据库。通过定义抽象类FileConvertor和数据库操作接口DataHandler,以及各自的实体类,实现了数据转换和数据库操作的解耦。
摘要由CSDN通过智能技术生成

某软件公司要开发一个数据转工具,可以将数据库中的数据转换成多种文件格式,例如TXT、XML、PDF等格式,同时该工具需要支持多种不同的数据库。试使用桥接模式对其进行设计,并使用Java代码编程模拟实现。

类图如下:

20软件2
第一步,定义一个抽象类FileConvertor(所有文件转换器的抽象类)
public abstract class FileConvertor 
{
   protected DataHandler handler;
   public abstract void convert(String filename);
   public void setHandler(DataHandler handler) 
   {
    this.handler=handler;
   }
}

第二步,定义实体类
TXTConvertor:将文件转换为TXT格式
public class TXTConvertor extends FileConvertor 
{
   public void convert(String filename) 
   {
    handler.readData();
    System.out.println("文件名:"+filename+",转换为TXT格式文件");
   }
}

PDFConvertor:将文件转换为PDF格式
public class PDFConvertor extends FileConvertor 
{
	public void convert(String filename) 
	   {
	    handler.readData();
	    System.out.println("文件名:"+filename+",转换为PDF格式文件");
	   }
}

XMLConvertor:将文件转换为XML格式
public class XMLConvertor extends FileConvertor 
{
	public void convert(String filename) 
	   {
	    handler.readData();
	    System.out.println("文件名:"+filename+",转换为XML格式文件");
	   }
}

第三步,定义数据库操作的接口
public interface DataHandler 
{
   public void readData();
}

第四步,定义实体类,数据库的操作器
OracleHandler:
(Oracle数据库)
public class OracleHandler implements DataHandler 
{
   public void readData() 
   {
	   System.out.print("导出oracle数据,");
   }
}

SQLServerHandler:
(SQLSever数据库)
public class SQLServerHandler implements DataHandler 
{
   public void readData() 
   {
	   System.out.print("导出sqlsever数据,");
   }
}

第五步,定义XMLUtils类,根据传入的参数type来调用实体类
import org.w3c.dom.*;
import java.io.*;
import javax.xml.parsers.*;
public class XMLUtils {
	public static Object getBean(String type) {
		try {
			DocumentBuilderFactory dFactory=DocumentBuilderFactory.newInstance();
			DocumentBuilder builder=dFactory.newDocumentBuilder();
			Document doc;
			doc=builder.parse(new File("src\\Day07\\config.xml"));
			NodeList nl=null;
			Node classNode=null;
			String cName=null;
			nl=doc.getElementsByTagName("className");
			if("Handler".equals(type)) {
				classNode=nl.item(0).getFirstChild();
			}
			else if("Convertor".equals(type)) {
				classNode=nl.item(1).getFirstChild();
			}
			cName=classNode.getNodeValue();
			Class c=Class.forName(cName);
			Object obj=c.newInstance();
			return obj;
		}catch(Exception e){
			e.printStackTrace();
			
		}
		return null;
	}
}

第六步,定义测试类
public class Client {
	public static void main(String[] args) {
		DataHandler handler = (DataHandler) XMLUtils.getBean("Handler");
		FileConvertor convertor = (FileConvertor) XMLUtils.getBean("Convertor");
        convertor.setHandler(handler);
        convertor.convert("yxxx");
	}
}

第七步,写配置文件(className分别为OracleHandlerTXTConvertor时的情况)

测试结果:

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秃头小霸王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值