2012-08-06 18 views
28

Tengo una clase llamada GoogleWeather, quiero convertirla a otra clase CustomWeather.Patrón de diseño para convertir una clase a otra

¿Hay algún patrón de diseño que te ayude a convertir las clases?

+0

Decorator pattern? – assylias

+0

¿Cuál es su jerarquía (hace CustomWeather extiende GoogleWeather)? ¿Qué quiere decir con "convertir"? – Flawyte

+0

Convertir como en ¿cómo? ¿Crear una subclase, cambiarle el nombre, etc.? No está claro lo que desea en la clase "CustomWeather" – russ36363

Respuesta

34

Hay una decisión crítica para hacer:

¿Necesita el objeto que se genera por la conversión para reflejar los cambios futuros en el objeto de origen?

Si no necesita tal funcionalidad, entonces el enfoque más simple es usar una clase de utilidad con métodos estáticos que crean un nuevo objeto basado en los campos del objeto fuente, como se menciona en otras respuestas.

Por otro lado, si usted necesita el objeto convertido para reflejar los cambios en el objeto de origen, probablemente tendría algo en la línea de la Adapter design pattern:

public class GoogleWeather { 
    ... 
    public int getTemperatureCelcius() { 
     ... 
    } 
    ... 
} 

public interface CustomWeather { 
    ... 
    public int getTemperatureKelvin(); 
    ... 
} 

public class GoogleWeatherAdapter implements CustomWeather { 
    private GoogleWeather weather; 
    ... 
    public int getTemperatureKelvin() { 
     return this.weather.getTemperatureCelcius + 273; 
    } 
    ... 
} 
+0

No entendí la diferencia entre el adaptador y el appperche del asignador cuál es la ventaja de usar el patrón de adaptador en este caso? – user1549004

+2

@ user1549004: el adaptador es un contenedor: todos los métodos se envían al objeto de origen. Eso significa que cualquier actualización del objeto fuente se propaga a través del adaptador. Por otro lado, el uso de una clase de mapeador es algo que ocurre una única vez: cualquier actualización de la fuente generalmente no afectará el resultado de la conversión. – thkala

+0

¿podría darme un ejemplo al usar una clase mapper en el caso de que las actualizaciones de la fuente no afecten el resultado de la conversión? – user1549004

37

En ese caso, me gustaría utilizar una clase Mapper con un montón de métodos estáticos:

public final class Mapper { 

    public static GoogleWeather from(CustomWeather customWeather) { 
     GoogleWeather weather = new GoogleWeather(); 
     // set the properties based on customWeather 
     return weather; 
    } 

    public static CustomWeather from(GoogleWeather googleWeather) { 
     CustomWeather weather = new CustomWeather(); 
     // set the properties based on googleWeather 
     return weather; 
    } 
} 

Así que no tienen dependencias entre las clases.

Ejemplo de uso:

CustomWeather weather = Mapper.from(getGoogleWeather()); 
+1

¿es un buen enfoque trabajar con Mapper? – user1549004

+4

¡De causa, es ** el mejor enfoque de todos los tiempos **! (Es una broma, pero bueno, no recomendaría malas soluciones aquí) –

+2

Algo que debe tenerse en cuenta: esta es una conversión de una sola vez; los cambios futuros en el objeto fuente no afectarán los campos del objeto resultante. – thkala

Cuestiones relacionadas