Bridge Design Pattern
(DP: Design Pattern)
This is one of the Structural Design Pattern.
It "decouples abstraction from its implementation".
What does it mean?
Example 1:
One can apply for a job through different platforms, such as Job Portal, Referral.
All these to the HR of the company.
So,
"HR" is the abstraction of different platforms i.e every platform "has " internal mechanism to pass on the resume to the HR. Platform internally passes the resume to the HR.
"Tech Requirement" is the abstraction of teams. Means the HR itself has the requirements different teams.
Here "HR" is acting as a bridge between the "Platform" and the "Team".
Example 2:
Lets say you have to create a reservation app, in which you could make flight and train reservations.
And the app should be compatible with different devices.
Example - Tablet, mobile, desktop.
So a user could reserve:
1) Flight Ticket on a Desktop
2) Train Ticket on a Desktop
3) Flight Ticket on a Tablet/mobile
4) Train Ticket on a Tablet/mobile
Congratulations you created your app fulfilling all the requirements and it has been a month since your app is up and running.
Oh no you come to know that now the user wants to add a new mode of transportation in the list, i.e. .
If you have created for every possible you will the number of classes.
To solve the above problem we use Briddge DP.
Our requirement is to make every device compatible with every m
Now every “Device” has access to every “Mode”.
Lets see how it is implemented-
Create interface for mode of transportation.
public interface IMode {
boolean makeReservaion();
}
As Flight and Train are modes; therefore; they will implement IMode interface:
1)
public class FlightMode implements IMode{
@Override
public boolean makeReservaion() {
System.out.println("Flight Reservation Done");
return true;
}
}
2)
public class TrainMode implements IMode{
@Override
public boolean makeReservaion() {
System.out.println("Train Reservation Done");
return true;
}
}
Now lets create device abstract class, which will have access to any mode of transportation-
abstract public class Device {
IMode mode;
Device(IMode mode){
this.mode = mode;
}
abstract void reserve();
}
Tablet and Desktop both are Devices so they will extend the Device abstract class:
1)
public class TabletDeviceImp extends Device{
TabletDeviceImp(IMode mode){
super(mode);
}
@Override
void reserve() {
this.mode.makeReservaion();
}
}
2)
public class DesktopDeviceImp extends Device{
DesktopDeviceImp(IMode mode){
super(mode);
}
@Override
void reserve() {
// TODO Auto-generated method stub
this.mode.makeReservaion();
}
}
Now when the user tries to reserve a "Flight" ticket from "Desktop" he will have to add the following code-
Device device = new DesktopDeviceImp(new FlightMode());
device.reserve();
So basically a Bridge DP by its name acts as a bridge in between implementation and its abstraction, making both of them independent of each other.
(You can ask it looks alike Decorator DP. In Decorator design pattern we change the of an object at runtime, whereas in this DP there is no change, we have just tweaked the structure little bit; the expected is intact)
GitHub: https://github.com/tanu02/Design-Patterns/tree/master/Bridge/src
Thanks for reading the article. I hope it helps.
Software Engineer @Bloomberg
5 年The article appears on Medium also?https://medium.com/@tanubatra02/briddge-design-pattern-574fb4c2124f