Adapter Pattern Demo
Demo
package AdapterPatternDemo;
public interface TemperatureReporter {
double getTemperatureCelsius();
}
package AdapterPatternDemo;
public class WeatherStationAdapter implements TemperatureReporter {
private OutsideWeatherStation weatherStation;
public WeatherStationAdapter(OutsideWeatherStation weatherStation) {
this.weatherStation = weatherStation;
}
@Override
public double getTemperatureCelsius() {
double fahrenheit = weatherStation.getTemperatureFahrenheit();
return (fahrenheit - 32) * 5.0 / 9.0;
}
}
package AdapterPatternDemo;
import java.util.List;
public class WeatherReporter {
private List<TemperatureReporter> stations;
public WeatherReporter(List<TemperatureReporter> stations) {
this.stations = stations;
}
public void report() {
for (TemperatureReporter station : stations) {
System.out.println("Current temperature in Celsius: " + station.getTemperatureCelsius());
}
}
}
Consider a scenario where a client application uses a TemperatureReporter
interface to report temperature in Celsius. However, there is a third-party library that provides a OutsideWeatherStation
class that reports temperature in Fahrenheit. We can't modify either the client or the third-party library, but we need to integrate them.
In this example, we have two OutsideWeatherStation
instances, each of which provides the temperature in Fahrenheit. Our WeatherReporter
expects a list of TemperatureReporter
objects, so we wrap our OutsideWeatherStation
objects in WeatherStationAdapter
instances. The WeatherReporter
can then call the getTemperatureCelsius
method on these objects, oblivious to the fact that it's actually getting the data from OutsideWeatherStation
objects.