恭喜,你发布的帖子
发布于 2022-07-08 16:39:26
10楼
这种问题的本质是:用FB内部的静态变量,做公共数据区来用,就像全局DB一样。而习惯上静态变量是做为需要封装起来的内部私有计算使用的。
弊端就是用FB的内部数据做公共区产生的。代码上固然可以实现,但丧失扩展性和可剪裁的柔性。
调度是需要封装的东西,尤其是当它变得越来越复杂。这样才能保证FB外部接口界面的使用无关性,而不是在FB外边还要再套一层机制,来解决管脚外面的调度约束。一个封装好的FB拿过来,外部管脚的使用越简单越好,而不是还要使用者在外部再自建一套管理。
这就和很多人都抢着上一个单间厕所一样,大家自主协调,有人占了你就等着,有人要是紧急憋不住了,你就让他夹塞先上。而不需要再额外设置一个厕所排序叫号的管理员。这需要每个参与者都把排序和竞争的规则,封装进各自头脑内部。
没看出有啥弊端哦。
只能说西门子编写功能块的严谨。
按版主常规这么用可以,直接一次列出多次调用也可以。给编程者最大的自由度。
请填写推广理由:
分享
只看
楼主