Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles
(untagged)

Bridge Pattern

0.00/5 (No votes)
23 Sep 2009 1  
The Bridge PatternThe bridge pattern decouples an abstraction from its implementation so the two can vary independently. In other words we make a

This articles was originally at wiki.asp.net but has now been given a new home on CodeProject. Editing rights for this article has been set at Bronze or above, so please go in and edit and update this article to keep it fresh and relevant.

The Bridge Pattern
The bridge pattern decouples an abstraction from its implementation so the
two can vary independently. In other words we make a bridge between
the abstraction and its implementation and therefore we won't have a
binding between the two. The pattern helps us whenever we need to
select or switch the implementation at runtime.


For a UML diagram of the pattern go to dofactory site.

Example in C#
How does it work? Lets look at a small example.

    #region The Abstraction

 

    public class Abstraction

    {

        #region Members

 

        private Bridge _bridge;

 

        #endregion

 

        #region Ctor

 

        /// <summary>

        /// Construct a new Abstraction object with

        /// the given bridge

        /// </summary>

        /// <param name="bridge">The given bridge</param>

        public Abstraction(Bridge bridge)

        {

            _bridge = bridge;

        }

 

        #endregion

 

        #region Methods

 

        /// <summary>

        /// The method demonstrate the call for

        /// the bridge object by its abstraction

        /// </summary>

        public void Operation()

        {

            Console.Write("Using");

            _bridge.OperationImplementation();

        }

 

        #endregion

    }

 

    #endregion

 

    #region The Bridge And Its Implementations

 

    public interface Bridge

    {

        void OperationImplementation();

    }

 

    public class BridgeImplementationA : Bridge

    {

        #region Bridge Members

 

        /// <summary>

        /// Perform implementation A operation

        /// </summary>

        public void OperationImplementation()

        {

            Console.Write("BridgeImplementationA");

        }

 

        #endregion

    }

 

    public class BridgeImplementationB : Bridge

    {

        #region Bridge Members

 

        /// <summary>

        /// Perform implementation B operation

        /// </summary>

        public void OperationImplementation()

        {

            Console.Write("BridgeImplementationB");

        }

 

        #endregion

    }

 

    #endregion

You can see that the abstraction holds a bridge object and gets the bridge in the
constructor. Therefore, whenever one of the implementation is needed you pass it
in the constructor and you won't be coupled to the implementation.

Summary
To sum up, use the bridge pattern whenever you identify that the operations
you write not always need to be implemented in the same way.
Another reason is not to bind the abstraction to its implementation.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here