4

可能重复:
注册表设计模式……好还是坏?

我正在开发一个使用 PHP 的游戏脚本,并以类似于我构建许多网站的方式来处理它。我有一个习惯,即声明一个变量,它是一个 stdClass,它包含许多其他对执行很重要的变量。然后,如果我需要函数内部的某些东西(如果它没有传入参数),我只需使用全局 $variable,在本例中为 $ar。

$ar = new stdClass;
$ar->i = new stdClass;
$ar->s = new stdClass;

$ar->i->root = "/home/user";

/* Directory where log files are to be stored. */
$ar->i->logs = "{$ar->i->root}/logs";

/* Directory where the banlist is. */
$ar->i->bl = "{$ar->i->root}/customize/settings/bannedaccounts.txt";

/* Directory where the silencelist is. */
$ar->i->sl = "{$ar->i->root}/customize/settings/silencedaccounts.txt";

/* How many points should be awarded for 1st place, 2nd place... etc. */
$ar->s->points = array(10, 7, 5, 4, 3, 2, 1, 1, 1, 1,1,1,1,1,1,1,1,1,1,1,1,1,1);

因此,如果我要在函数中使用上述变量之一,我会这样处理它。

public function run() {
  global $ar;
  //do something with the variable..
}

有人会建议不要这样做吗?使用单个变量并将其包含在许多函数中是一种避免的坏习惯吗?我知道创建只使用给定参数的函数是可取的,但我问的是 PHP 性能而不是编程清晰度。谢谢!

4

1 回答 1

1

聚集在一起表示一个对象的数据元素应该是一个对象。如果你有不相关的东西,不要把它塞进同一个对象里。

如果您需要全局范围(通常不需要),您可以使用$GLOBALS. 但是,对于大多数项目,我建议您遵循 OOP 原则。至少,使用函数参数。

如果您有一个像run()这样的函数库需要这些变量(或者,甚至只是run()!),请拥有一个实用程序类,其中这些变量是该类的成员。

于 2013-01-10T04:36:53.867 回答