写的程序的插件系统发现有好几个插件调用了同一个接口,我想知道如何解决先后执行的问题。比如说我有如下的场景:
A插件和B插件都调用了xxoo接口,A插件用来在这个接口生成东西的,B插件是来统计整个页面的运行时间的。
实际使用上B在A前面就执行了,这样就有问题了。因为插件系统设置的是直接遍历所有的插件,如果有这个钩子函数的话就执行,所以没办法绝对控制A和B的执行顺序。
我想问一下如何(改进我的插件系统)才能达到我的效果?
写的程序的插件系统发现有好几个插件调用了同一个接口,我想知道如何解决先后执行的问题。比如说我有如下的场景:
A插件和B插件都调用了xxoo接口,A插件用来在这个接口生成东西的,B插件是来统计整个页面的运行时间的。
实际使用上B在A前面就执行了,这样就有问题了。因为插件系统设置的是直接遍历所有的插件,如果有这个钩子函数的话就执行,所以没办法绝对控制A和B的执行顺序。
我想问一下如何(改进我的插件系统)才能达到我的效果?
半夜睡不着了,答个题玩玩儿。
插件之间不应该耦合。
既然是插件,那么A就不应该知道B的存在,反之依然。
那么,A调用系统接口的时候,他不知道还有多少个插件也要调用此接口,也许是在他之前,也许是在他以后,也许是和他同时。
如果你是插件开发者,就应该考虑这方面的问题,不能因为系统安装了你的插件导致其他的好多插件不能正常工作了。
但是插件之间相互调用,相互影响的情况也有,比如 jq 的幻灯片插件就需要使用到动画功能,php 的
验证码模块就依赖于 gd 库。因此,可以在插件的配置文件中写明此插件的依赖关系。
假设 A 依赖于 B,放系统在加载 A 时,B 没有加载的话,系统会去加载 B,然后再加载 B。
至于顺序和优先级,我觉得没有必要。只要搞好依赖关系就行。
要看插件之间的耦合度 一个插件和多个插件有关 最好合并成一个
如果与所有插件有关的逻辑 最好放到系统里而不是插件形式
按名字的字典序,或者注册顺序(如果插件需要通过某种方式「注册」的话),或者添加一个优先级字段。
或者更复杂一些,插件可以指定它在哪些插件之前或者之后执行。