import java.io.Serializable; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; interface IConnection { public void query(String sql); } interface IDriver { public DIALECT getDialect(); public IConnection getConnection(); } public class Bridge { public static void main(String[] args) { DriverManager.registerDriver(new MySqlDriver()); IConnection mysql = DriverManager.getConnection(); mysql.query("select * from table"); DriverManager.registerDriver(new OracleDriver()); IConnection oracle = DriverManager.getConnection(DIALECT.ORACLE); oracle.query("insert into table"); IConnection db2 = DriverManager.getConnection(DIALECT.DB2); db2.query("update table"); } } enum DIALECT implements Serializable { MYSQL,ORACLE,DB2; } class DriverManager { private static Map<DIALECT, IDriver> drivers = new ConcurrentHashMap<DIALECT, IDriver>(); private static final DIALECT DEFAULT_DIALECT = DIALECT.MYSQL; private DriverManager() { } public static void registerDriver(IDriver driver) { drivers.put(driver.getDialect(), driver); } public static IConnection getConnection() { return getConnection(DEFAULT_DIALECT); } public static IConnection getConnection(DIALECT dialect) { IDriver driver = drivers.get(dialect); if (driver == null) throw new IllegalArgumentException("no driver register with " + dialect); return driver.getConnection(); } } class MySqlDriver implements IDriver { @Override public IConnection getConnection() { return new IConnection() { @Override public void query(String sql) { System.out.println("MySql query ('" + sql + "') is executing......"); } }; } @Override public DIALECT getDialect() { return DIALECT.MYSQL; } } class OracleDriver implements IDriver { @Override public IConnection getConnection() { return new IConnection() { @Override public void query(String sql) { System.out.println("Oracle query ('" + sql + "') is executing......"); } }; } @Override public DIALECT getDialect() { return DIALECT.ORACLE; } } class DB2Driver implements IDriver { @Override public IConnection getConnection() { return new IConnection() { @Override public void query(String sql) { System.out.println("DB2 query ('" + sql + "') is executing......"); } }; } @Override public DIALECT getDialect() { return DIALECT.DB2; } }
输出为:
MySql query ('select * from table') is executing......
Oracle query ('insert into table') is executing......
Exception in thread "main" java.lang.IllegalArgumentException: no driver register with DB2
* jdbc api使用bridge模式 Service / DAO
* bridge是在设计之初的模式,adapter是针对已有系统的代码。
* 通过对象组合的方式,Bridge模式把两个角色之间的继承关系改为了耦合的关系,从而使这两者可以
从容自若的各自独立的变化,这也是Bridge模式的本意。
public abstract class Abstraction {
protected Implementor implementor;
public Abstraction(Implementor implementor) {
this.implementor = implementor;
}
public void operation() {
implementor.operationImpl();
}
}
public interface Implementor {
public void operationImpl();
}
class ConcreteImplementorA implements Implementor {
@Override public void operationImpl() {
// 真正的实现
System.out.println("具体实现A");
}
}
class ConcreteImplementorB implements Implementor {
@Override public void operationImpl() {
// 真正的实现
System.out.println("具体实现B");
}
}
class RefinedAbstraction extends Abstraction {
public RefinedAbstraction(Implementor implementor) {
super(implementor);
}
@Override public void operation() {
//do someting
super.operation();
//do other thing
}
}
* Facade模式注重简化接口,Adapter模式注重转换接口,Bridge模式注重分离接口(抽象)与其实现,
Decorator模式注重稳定接口的前提下为对象扩展功能。
相关推荐
Bridge模式是一种结构型设计模式,它将抽象部分与其实现部分分离,使它们可以独立进行变化。在Bridge模式中,抽象类(Abstract Class)和实现类(Implementor Class)是两个独立的继承体系,通过一个“桥梁”类...
Bridge模式是一种设计模式,属于结构型模式之一,其主要目的是将抽象部分与实现部分分离,使得两者可以独立地进行变化。这种模式的核心思想是“抽象不应该依赖于具体,而应该依赖于抽象”。Bridge模式通过引入一个...
本文将介绍 Bridge 模式,它是一种结构型设计模式,用于解耦抽象与实现,增强软件系统的灵活性和可扩展性。 二、Bridge 设计模式的别名 Handle/Body 三、Bridge 设计模式的意图 Bridge 设计模式是 Java 中的一种结构...
本资料主要探讨了Docker的网络桥接模式(Bridge模式)以及其默认网络设备docker0,这对于理解和运用Docker服务至关重要。 首先,Docker的Bridge模式是Docker容器默认的网络模式。在这个模式下,每个容器都会被分配...
Bridge模式是一种设计模式,主要目的是将抽象部分与实现部分解耦,使得它们可以独立地进行变化。在Java编程中,这种模式的应用可以帮助我们构建更灵活、可扩展的系统。Bridge模式通常由四个主要角色组成:抽象...
Bridge模式是对抽象和具体的进一步抽象。假设你有一个抽象类,一个具体类,现在需要将两者的变化都考虑进去,这就需要bridge。这是经典设计模式中唯一的可以同时处理抽象和具体同时变化的设计模式
Docker在创建容器时有四种网络模式,bridge为默认不需要用--net去指定,其他...那Docker为网络bridge模式指定容器ip该如何实现呢?下面通过通过这篇文章一起看看吧,文中给出了详细的示例代码,有需要的可以参考借鉴。
桥模式(Bridge模式)是一种设计模式,主要用于将抽象部分与实现部分解耦,使得它们能够独立地变化。在Java中,这种模式可以帮助我们构建更加灵活和可扩展的系统。以下是关于桥模式的详细解释: 首先,理解桥模式的...
软件设计模式,共包含二十多种模式,做IT的必备知识呀!
在给定的文件列表中,我们可以看到涉及到Bridge模式的一些关键组件: 1. **Abstraction**(抽象类):这是桥接模式的核心抽象部分,定义了客户需要的接口,并持有一个指向实现部分的指针。在`abstraction.cpp`和`...
这就要使用Bridge模式。 意图 将抽象部分与实现部分分离,使它们都可以独立的变化。[GOF《设计模式》] 结构图图1Bridge模式结构图 生活中的例子 桥接模式将抽象部分与它的实现分离,使它们能够独立地变化。一个...
《Java实现的23种设计模式——Bridge模式详解》 设计模式是软件工程中的宝贵经验总结,它们为解决常见问题提供了可复用的解决方案。在众多设计模式中,Bridge模式是一种结构型模式,旨在将抽象部分与其实现部分分离...
Java设计模式中的Bridge模式是一种结构型设计模式,其主要目的是将抽象部分与其实现部分分离,使得两者可以独立地进行变化。在Bridge模式中,抽象类(或接口)不直接包含实现,而是通过一个引用(或接口)指向实现类...
在上述例子中,Bridge模式被用来解决咖啡种类的问题。咖啡可以按照杯型(中杯、大杯)和是否加奶(加奶、不加奶)来分类。如果简单地使用继承,会形成一个四层的类结构,这将导致类的复杂性和扩展困难。Bridge模式...
我们需要选择Bridge模式,并启用DHCP使能。这将允许电脑连接光猫时可以自动获得IP地址。然后,我们需要访问光猫的配置页面,并勾选业务模式为INTERNET,vlan模式改为TAG,vlanid为200,802.1p优先级为6。 步骤3:...
Bridge 模式是一种结构型模式,用于提供一种分离对象的接口和实现的接口。Bridge 模式的优点是可以提供一种统一的分离对象的接口和实现的接口,减少了代码的耦合度。Bridge 模式的缺点是它可能会增加代码的复杂度。 ...
Bridge 模式是一种结构型设计模式,主要用于将抽象部分与实现部分分离,使得它们可以独立地变化。它可以使得抽象部分和实现部分之间的绑定变得松散,从而提高了系统的灵活性和可维护性。 2. ACE 框架中的 Bridge ...