服务提供者框架是指:多个服务提供者实现一个服务,系统为客户端提供多个实现,并把他们从多个实现中解耦出来。服务提供者的改变对它们的客户端是透明的,这样提供了更好的可扩展性。例如,JDBC,JMS等就是用了服务提供者框架
从字面意思看就是:实何实现服务提供者提供服务功能的设计结构,主体有服务、服务提供者。反映到我们程序中,通常有四个组件:
Service Interface:服务接口,将服务通过抽象统一声明,供客户端调用、由各个服务提供者具体实现。
Provider Registration API:服务提供者注册API,用于系统注册服务提供者,使得客户端可以访问它实现的服务。
Service Access API:服务访问API,用户客户端获取相应的服务。
Service Provider Interface:服务提供者接口,这些服务提供者负责创建其服务实现的实例。(可选)
以jdbc为例,下面是jdbc获取Connection连接的示例
//加载MySql驱动
Class.forName("com.mysql.jdbc.Driver");
//加载Oracle驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection conn = (Connection) DriverManager.getConnection(url, username, password);
1.在这里面 Connection 就是JDBC的服务接口,客户端不用关心具体的各个服务提供者的实现逻辑,使用Connection就可以了。
2.Class.forName(“…”)会实例化一个com.mysql.jdbc.Driver类(服务提供者接口的实现类),并将这个类的实例注册到DriverManager.registerDriver(提供者注册API);
以com.mysql.jdbc.Driver 为例看看他做了什么
*/
public class Driver extends NonRegisteringDriver implements java.sql.Driver {
//
// Register ourselves with the DriverManager
//
static {
try {
java.sql.DriverManager.registerDriver(new Driver());
} catch (SQLException E) {
throw new RuntimeException("Can't register driver!");
}
}
他在这里向DriverManager注册了一个实例,所以后面才可以获取到。
3.通过建立连接的URL,用户名,密码来获取链接到mysql数据库的Connection服务。DriverManager.getConnection()是服务访问API, 返回的是具体的实现类对象。
4.Driver就是服务提供者接口。