Design patterns
Multiton
Szukaj…
Uwagi
Zapalenie wielonerwowe
Podobnie jak Singleton , Multiton można uznać za złą praktykę. Są jednak chwile, kiedy można z niego mądrze korzystać (na przykład, jeśli budujesz system taki jak ORM / ODM w celu utrwalenia wielu obiektów).
Pula singletonów (przykład PHP)
Multiton może być używany jako pojemnik na singletony. To implementacja Multiton jest kombinacją wzorców Singleton i Pool.
Oto przykład, w jaki sposób można utworzyć wspólną klasę puli abstrakcyjnej Multiton:
abstract class MultitonPoolAbstract
{
/**
* @var array
*/
protected static $instances = [];
final protected function __construct() {}
/**
* Get class name of lately binded class
*
* @return string
*/
final protected static function getClassName()
{
return get_called_class();
}
/**
* Instantiates a calling class object
*
* @return static
*/
public static function getInstance()
{
$className = static::getClassName();
if( !isset(self::$instances[$className]) ) {
self::$instances[$className] = new $className;
}
return self::$instances[$className];
}
/**
* Deletes a calling class object
*
* @return void
*/
public static function deleteInstance()
{
$className = static::getClassName();
if( isset(self::$instances[$className]) )
unset(self::$instances[$className]);
}
/*-------------------------------------------------------------------------
| Seal methods that can instantiate the class
|------------------------------------------------------------------------*/
final protected function __clone() {}
final protected function __sleep() {}
final protected function __wakeup() {}
}
W ten sposób możemy utworzyć instancję różnych pul Singleton.
Rejestr singletonów (przykład PHP)
Ten wzorzec może być używany do rejestrowania zarejestrowanych pul singletonów, z których każdy wyróżnia się unikalnym identyfikatorem:
abstract class MultitonRegistryAbstract
{
/**
* @var array
*/
protected static $instances = [];
/**
* @param string $id
*/
final protected function __construct($id) {}
/**
* Get class name of lately binded class
*
* @return string
*/
final protected static function getClassName()
{
return get_called_class();
}
/**
* Instantiates a calling class object
*
* @return static
*/
public static function getInstance($id)
{
$className = static::getClassName();
if( !isset(self::$instances[$className]) ) {
self::$instances[$className] = [$id => new $className($id)];
} else {
if( !isset(self::$instances[$className][$id]) ) {
self::$instances[$className][$id] = new $className($id);
}
}
return self::$instances[$className][$id];
}
/**
* Deletes a calling class object
*
* @return void
*/
public static function unsetInstance($id)
{
$className = static::getClassName();
if( isset(self::$instances[$className]) ) {
if( isset(self::$instances[$className][$id]) ) {
unset(self::$instances[$className][$id]);
}
if( empty(self::$instances[$className]) ) {
unset(self::$instances[$className]);
}
}
}
/*-------------------------------------------------------------------------
| Seal methods that can instantiate the class
|------------------------------------------------------------------------*/
final protected function __clone() {}
final protected function __sleep() {}
final protected function __wakeup() {}
}
Jest to uproszczona forma wzorca, której można użyć dla ORM do przechowywania kilku jednostek danego typu.