很多PHP开发人员都知道, 使用类的静态成员函数效率比类的普通成员函数的要高,本文从应用层次分析这个问题
下面是一个范例:
代码如下:
PHP // PHP静态方法测试@H_502_7@header('Content-Type: text/html; charset=utf-8');@H_502_7@class xclass{@H_502_7@ public static $var1 = '1111111111111111';@H_502_7@ public $var2 = 'aaaaaaaaaaaaa';@H_502_7@ public function __construct()@H_502_7@ {@H_502_7@ $this -> var2 = 'bbbbbbbbbbbbbbbb';@H_502_7@ }@H_502_7@ public static function secho1()@H_502_7@ {@H_502_7@ echo self :: $var1 . '
';@H_502_7@ }@H_502_7@ public function secho2()@H_502_7@ {@H_502_7@ echo $this -> var2 . '
';@H_502_7@ }@H_502_7@ public function secho3()@H_502_7@ {@H_502_7@ echo 'cccccccccccccc
';@H_502_7@ }@H_502_7@ }@H_502_7@xclass :: secho1();@H_502_7@xclass :: secho3();@H_502_7@echo "------------------------------
";@H_502_7@$xc = new xclass();@H_502_7@$xc -> secho1();@H_502_7@$xc -> secho2();@H_502_7@?>
@H_502_7@认真看上面的范例,会发现一个有趣的地方,secho1()定义为静态方法后, 在动态类的对像实例中仍可以引用为动态方法,而secho3()也可以被当作静态成员函数,从这个层面,不难理解为什么说静态成员函数比动态的快。
';@H_502_7@ }@H_502_7@ public function secho2()@H_502_7@ {@H_502_7@ echo $this -> var2 . '
';@H_502_7@ }@H_502_7@ public function secho3()@H_502_7@ {@H_502_7@ echo 'cccccccccccccc
';@H_502_7@ }@H_502_7@ }@H_502_7@xclass :: secho1();@H_502_7@xclass :: secho3();@H_502_7@echo "------------------------------
";@H_502_7@$xc = new xclass();@H_502_7@$xc -> secho1();@H_502_7@$xc -> secho2();@H_502_7@?>
可能是由于兼容性原因,
PHP的类成员其实并无明显的动静态之分,所有成员在没明确声明的情况下都会被当成静态成员存放在特定的内存区中
,所以调用静态成员函数就和调用普通函数一样,速度很快。但调用动态类则不同,它要以这个类结构作为样本,在内存中重新生成一个对象实例,所以多了一个过程,这对于简单的类来说,可能不算什么,但对于复杂的类来说这是明显影响效率的。
有人会担心,使用静态方法会不会造成内存占用过多,其实从上面分析可以知道,你不声明静态方法,系统依然会把成员当成静态,因此对于一个完全静态方法的类和一个完全动态但没声明实例对象的类占用内存几乎是一样的,所以对于比较直接的逻辑,都建议直接用静态成员方法,当然,一些复杂或对像化明显的逻辑,如果完全用静态类也不是没可能,但那样就失去类的意义了,如果这样,何必OOP,按用途,静态方法特别适用于MVC模式的逻辑类中。