JDBC源码分析&桥接模式

JDBC对于java的开发人员来说并不陌生,它封装了ODBC,简化了java连接数据库的开发,本文我从部分JDBC的源码入手来阐述一下JDBC。


桥接模式是由Gang of four整理的23种设计模式中的一种,JDBC是桥接模式一个典型的例子。了解JDBC源码,能让我们更好地理解桥接模式的意图和实现;了解桥接模式,能让我们更清楚JDBC设计的优越之处。

 

首先我们先来看下桥接模式的意图,它旨在将抽象部分与实现部分分离,使其可以独立地变化,废话不多说,我们直接看一张UML图:

其实最初我在看这句意图的时候非常的郁闷,作为一名开发人员,对抽象与实现的第一反应就是接口实现或者类继承,接口和实现类独立地变化本身就是一件让我觉得很郁闷的事情,但是看了这张UML图之后便恍然大悟了,这里的抽象与实现是聚合关系,也就是我们口头常说的调用者和被调用者,这样一来桥接模式的意图就很清楚了,其实某种意义上就是解耦了某个功能的抽象定义和具体实现,让其变成了两个互相独立的模块。

 

让我们回到JDBC的源码,首先请大家打开JDK API,翻到java.sql包:

可以发现,java.sql包不同于其他几乎所有的包,它基本可以说没有定义多少类,但是定义了大量的接口,而由各个数据库公司去写这些接口的实现类:

 

可以看到,sum公司仅仅是提出了一系列接口规范,数据库公司做出实现,然后当你真的需要连接某个数据库时,你需要先添加数据库公司发布的jar包,如jdbc-mysql.jar,然后在使用时先加载Driver:

 

                try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			System.out.println("找不到驱动程序类 ,加载驱动失败!");
			e.printStackTrace();
		}


然后就可以通过DriverManager去获取连接:

 

 

		try {
			conn = (Connection) DriverManager.getConnection(url , username , password );
		} catch (SQLException e) {
			System.out.println("数据库连接失败!");
			e.printStackTrace();
		} </
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值