class ConnectionFactory
{
private static $factory;
public static function getFactory()
{
if (!self::$factory)
self::$factory = new ConnectionFactory(...);
return self::$factory;
}
private $db;
public function getConnection() {
if (!$db)
$db = new PDO(...);
return $db;
}
}
function getSomething()
{
$conn = ConnectionFactory::getFactory()->getConnection();
.
.
.
}
有几件我不懂的东西
!db
做什么ConnectionFactory::getFactory()->getConnection();
getFactory
方法答案 0 :(得分:3)
4
public static function getFactory()
{
if (!self::$factory) // is self::$factory initialised?
self::$factory = new ConnectionFactory(...); //initialise it
return self::$factory; //return self::$factory
}
此外,$ factory似乎是一个设置在某处的变量。据推测,它可能包含几个不同的类名。不会改变函数的工作方式。它是单身模式
添加有关此模式的有趣链接wikipedia
答案 1 :(得分:1)
对于1.是,可以使用ClassName :: $ staticvarname
始终访问类的静态属性对于2.肯定存在一个错误。应该是if(!$ this-> db)和getConnection中的所有代码都应该使用$ this-> db而不是$ db。
getFactory()在这里是Singleton模式的更标准的getInstance()的“别名”。 它返回类的单个实例,如果存在&如果不存在则创建单个实例。
getFactory() - > getConnection()调用很简单: getFactory()返回ConnectionFactory类的单个实例。 因此,现在您拥有Singleton实例,您可以对其执行任何调用。 getConnection()返回由单例处理的“单个”PDO实例(存储在$ db成员中)
答案 2 :(得分:1)
答案 3 :(得分:1)
NOT
。它通常被视为!=,表示NOT EQUAL
。在这种情况下,正在检查是否已创建db对象,因此这意味着db为NOT NULL
。 3& 4.您指定的方法是使用该类(不实例化它),并调用getFactory()。如果是NOT NULL
,将创建该因子,否则,它将返回已创建的工厂。之后,它使用返回的工厂的instance
请求连接。由于只有一个工厂,我们可以假设一旦连接被实例化(与工厂实例化的方式相同),那么该连接将可用于工厂前进的所有用途
我建议阅读关于Singleton模式的wikipedia article。希望这可能有用。 同样,请记住,一般来说,单身模式被认为是一种应该避免的反模式。在我看来,这个类可以很容易地创建为带有静态getConnection方法的静态类。随着代码的显示,似乎在这里创建它本身毫无意义。但是,这只是在这个小范围内。