Recientemente realicé una refactorización de un proyecto de tamaño mediano en Java para volver y agregar pruebas unitarias. Cuando me di cuenta de lo difícil que era burlarse de los solteros y las estadísticas, finalmente "entendí" lo que he estado leyendo sobre ellos todo este tiempo. (Soy una de esas personas que necesita aprender de la experiencia. Oh, bueno).
Entonces, ahora que estoy usando Spring para crear los objetos y conectarlos, me estoy deshaciendo de las static
palabras clave izquierda y derecha. (Si pudiera querer burlarme de él, no es realmente estático en el mismo sentido que Math.abs (), ¿verdad?) La cuestión es que me había acostumbrado a usar static
para denotar que un método no confiaba en cualquier estado del objeto. Por ejemplo:
//Before
import com.thirdparty.ThirdPartyLibrary.Thingy;
public class ThirdPartyLibraryWrapper {
public static Thingy newThingy(InputType input) {
new Thingy.Builder().withInput(input).alwaysFrobnicate().build();
}
}
//called as...
ThirdPartyLibraryWrapper.newThingy(input);
//After
public class ThirdPartyFactory {
public Thingy newThingy(InputType input) {
new Thingy.Builder().withInput(input).alwaysFrobnicate().build();
}
}
//called as...
thirdPartyFactoryInstance.newThingy(input);
Entonces, aquí es donde se pone sensible. Me gustaba la vieja manera porque la letra mayúscula me decía que, al igual que Math.sin (x), ThirdPartyLibraryWrapper.newThingy (x) hacía lo mismo de la misma manera cada vez. No hay estado de objeto para cambiar cómo hace el objeto lo que le pido que haga. Aquí hay algunas respuestas posibles que estoy considerando.
- Nadie más se siente así, así que hay algo mal conmigo. ¡Tal vez no he internalizado realmente la forma OO de hacer las cosas! Tal vez estoy escribiendo en Java pero pensando en FORTRAN o somesuch. (Lo cual sería impresionante ya que nunca he escrito FORTRAN).
- Tal vez estoy usando la estática como una especie de proxy para la inmutabilidad con el propósito de razonar sobre el código. Dicho esto, ¿qué pistas debo tener en mi código para que alguien venga a mantenerlo para saber qué tiene estado y qué no?
- ¿Quizás esto debería ser gratis si elijo buenas metáforas de objetos? por ejemplo
thingyWrapper
, no parece que tenga un estado independiente de la envoltura,Thingy
que puede ser mutable. Del mismo modo, unthingyFactory
sonido debería ser inmutable, pero podría tener diferentes estrategias que se eligen en la creación.