【发布时间】:2017-06-03 10:19:19
【问题描述】:
我见过几个answers on object destruction order,都指出不能保证顺序。由于我无法控制顺序,我想在所有对象都被销毁后调用一个函数。
register_shutdown_function 在对象销毁之前被调用,因此不是一个选项。我已经查看了使用对象的 set_error_handler 之类的技巧,因此它被“延迟”调用,但这还不够。
有关问题的一些背景,这是一个complex CMS,其中包含数十个用于路由(视图)层的单独文件。有一个常见的引导包括,但不是一个常见的在关机时运行。我通过一个常见的继承基类使用 APCu 对象缓存,并且需要确保清除对象。对于在页面加载期间创建的同一对象的任何两个实例,一个可能想要清除自己,而另一个可能想要缓存自己。显然 purge 胜过所有其他事情,所以我需要在一组全局缓存键上调用 apc_delete 来清除所有 __destruct()'ion 完成。
【问题讨论】:
-
有趣的问题。 “对于在页面加载期间创建的同一对象的任何两个实例,一个可能想要清除自己,而另一个可能想要缓存自己”听起来像是一个设计缺陷。你不总是希望一个对象的所有实例都是最新的吗?我认为您的缓存/加载层会处理这个问题。 (我对bitweaver一无所知。)
-
嗨,马特,设计缺陷评论让我思考。您是对的,现在我将在尝试将对象存储在缓存中之前检查已清除列表。这是一个更合适的解决方案,但是如果可能的话,我仍然很想知道如何在 PHP 中执行最终的“最后调用”函数。
标签: php php-internals apcu bitweaver