我试图理解CodeIgniter中的框架结构,我刚刚开始并想出了这个小小的误解。
有人可以帮我解决以下问题: -
1-为什么他们使用引用传递类的实例...我的意思是为什么不只是一个简单的变量?
2-为什么函数将类的名称存储在数组中而不是“字符串变量”(请不要判断我的php术语是最糟糕的)...?!
static $_classes = array();
^^^^^^^ this cloud be just ("") or am i missing something
这是函数所以你不会去寻找它。
function &load_class($class, $directory = 'libraries', $prefix = 'CI_')
{
static $_classes = array();
// Does the class exist? If so, we're done...
if (isset($_classes[$class]))
{
return $_classes[$class];
}
$name = FALSE;
// Look for the class first in the local application/libraries folder
// then in the native system/libraries folder
foreach (array(APPPATH, BASEPATH) as $path)
{
if (file_exists($path.$directory.'/'.$class.'.php'))
{
$name = $prefix.$class;
if (class_exists($name) === FALSE)
{
require($path.$directory.'/'.$class.'.php');
}
break;
}
}
// Is the request a class extension? If so we load it too
if (file_exists(APPPATH.$directory.'/'.config_item('subclass_prefix').$class.'.php'))
{
$name = config_item('subclass_prefix').$class;
if (class_exists($name) === FALSE)
{
require(APPPATH.$directory.'/'.config_item('subclass_prefix').$class.'.php');
}
}
// Did we find the class?
if ($name === FALSE)
{
// Note: We use exit() rather then show_error() in order to avoid a
// self-referencing loop with the Excptions class
exit('Unable to locate the specified class: '.$class.'.php');
}
// Keep track of what we just loaded
is_loaded($class);
$_classes[$class] = new $name();
return $_classes[$class];
}
答案 0 :(得分:7)
关键是static
之前的$_classes = array();
关键字。这使得$_classes
数组在多次调用函数之间保持它的值。基本上,它们将它用作实例化类的本地缓存。为此,字符串不起作用。
详细了解静态关键字in the manual。
至于引用返回,我认为这是php4行李,在php4上支持CI直到2.x.您可能会发现此blogpost helpful以查看从php4更改为php5的内容。
答案 1 :(得分:1)
传递一个普通(非参考)变量“似乎”可以正常工作,因为每次传递它时,前一个实例都会被覆盖,最后一个或最新的实例将占据该位置。所以每次你创建一个新的类实例。但这有两个原因造成的浪费......
它创建了一个新的实例变量,而没有取消设置前一个变量(尽管PHP会最终对这些变量进行垃圾收集),从而保留了被某些恶意代码读取并在宝贵的服务器空间中浪费几个字节的风险您必须为此付费。
实例意味着一个州。 “输入”状态,“安全”状态,“配置”状态等。如果您创建了一个新变量,则表示您正在创建这些状态的副本。如果您偶然犯了任何错误,那么您在“输入”实例中保存的当前状态可能不会更改以反映当前或最新状态。假设另一个已经改变;如果你在不同的场合使用它们,那么下一步可能会导致冲突和灾难。