您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

PHP推延静态绑定

2025/12/11 14:44:46发布16次查看
php延迟静态绑定
最近项目中遇到这样一个case,感觉所有的model类都须是单例性能更高.因为所有的model皆继承统一父类basemodel,所以在basemodel中添加控制单例的代码,简单演示如下:
/*基类*/class basemodel{ private static $instance = null; public static function instance() { if (empty(self::$instance)) { self::$instance = new self(); } return self::$instance; }}
然后是各个逻辑子类model
/*商品类*/class goodmodel extends basemodel{ public function getinfobyid($goodid){ return array( 'id'=>$goodid, 'name'=>'小苹果', 'logo'=>'http://t3.qlogo.cn/mbloghead/65518bb9e5287fcd5864/180' ); }}################################################################$good = goodmodel::instance();var_dump($good);
此类$good 为
object(basemodel)#1 (0) {}
非需要的goodmodel
这是就需要介绍self
self::调用的变量只是该类的 即使该类被继承 变量被重写 调用父类里的函数 self::调用的变量还是输出父类的变量值 而不会输出被重写的值
所以需要采用static关键字延迟静态绑定,static代表了子类
代码如下
/*基类*/class basemodel{ private static $instance = null; public static function instance() { if (empty(self::$instance)) { self::$instance = new static(); } return self::$instance; }}
这时的$good 即为
object(goodmodel)#1 (0) {}
其实也可用get_called_class函数来解决上面的问题,代码如下
class basemodel{ private static $instance = null; public static function instance() { if (empty(self::$instance)) { $classname = get_called_class(); self::$instance = new $classname(); } return self::$instance; }}
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product