Últimamente ha habido algún tipo de revolución contra los solteros, pero ¿hay algo malo en ellos si son apátridas?
Sé el uso excesivo y todo ... esto se aplica a todo, no solo a los solteros.
Últimamente ha habido algún tipo de revolución contra los solteros, pero ¿hay algo malo en ellos si son apátridas?
Sé el uso excesivo y todo ... esto se aplica a todo, no solo a los solteros.
Respuestas:
> Are immutable/stateless singletons bad?
Para más detalles ver the-onion-architecture
No veo otras razones por las que no usar Singletons.
Siempre depende del uso. Creo que la revolución viene del hecho de que cada programador aprende este patrón como el patrón orientado a objetos. La mayoría se olvida de pensar dónde tiene sentido y dónde no.
Esto, por supuesto, es cierto para cada patrón. Simplemente usando patrones no creas un buen código o un buen software.
Si tiene un singleton sin estado, ¿por qué no usar una clase que ofrezca solo métodos estáticos (o usar una clase estática)?
Aquí algunas publicaciones sobre variables globales y singletons en general.
No sería tan estricto como el autor, pero muestra que para la mayoría de los casos en los que crees que necesitas un singleton, realmente no lo necesitas.
No hay nada que un singleton sin estado inmutable pueda hacer que una clase estática no pueda hacer.
Simplemente no hay razón para agregar el nivel adicional de complejidad que crea -> Instance (), mientras que la simple llamada a un método estático será más clara, más conservadora en términos de recursos y probablemente más rápida.
No es que estén equivocados. Es que hay una mejor manera de hacerlo. Hay escenarios en los que los singletons normales ("con estado") son el camino correcto. Lo malo de singleton es que a menudo se abusa de ellos, con los mismos malos resultados que las variables globales, pero hay casos específicos en los que usar un singleton es simplemente correcto. No hay tales casos para los apátridas.
El principal problema con el singleton es que oculta las dependencias y se acopla especialmente cuando se usa en situaciones transversales. Vea Singletons son mentirosos patológicos o Why Singletons Evil para leer más.
Por otro lado, un estado menos único, si no se abusa, puede ser útil y mejorar el rendimiento. Considere un ejemplo:
interface Interface
{
void Method();
}
class StatelessSingleton : Interface
{
public static readonly StatelessSingleton Instance = new StatelessSingleton();
private StatelessSingleton() { }
public void Method() { }
}
class User
{
public User(Interface i) { /* ... */ }
}
Aquí, StatelessSingleton actúa como implementación predeterminada de la interfaz y se coloca en el constructor de usuario. No hay acoplamientos codificados ni dependencias ocultas. No podemos usar una clase estática debido a la interfaz subyacente, pero no hay ninguna razón para crear más de una instancia de un valor predeterminado. Es por eso que un singleton sin estado parece ser una opción adecuada.
Sin embargo, tal vez deberíamos usar otro patrón para una implementación predeterminada:
class Implementation : Interface
{
private readonly Action _method;
public Implementation()
{
_method = new Action(() => { /* default */ });
}
public Implementation(Action custom)
{
_method = custom;
}
public void Method()
{
_method();
}
}
Alcanza el rendimiento con respecto a StatelessSingleton pero constituye una implementación genérica de la interfaz. La interfaz IProgress utiliza una solución similar .
Aunque de nuevo, ¿por qué permitir crear más de una implementación de comportamiento predeterminado? Sin embargo, podemos combinar los dos:
class Implementation : Interface
{
public readonly Implementation Default = new Implementation();
private readonly Action _method;
private Implementation()
{
_method = new Action(() => { /* default */ });
}
public Implementation(Action custom)
{
_method = custom;
}
public void Method()
{
_method();
}
}
En conclusión, creo que hay lugares (como los valores predeterminados representados) donde los Singleton son útiles. La definición principal de Singleton establece que no permite crear más de una instancia de una clase. Es como la energía nuclear. Puede producir una energía o una bomba. Depende de los humanos.