AI小西
热门搜索
1847工业学习平台与计算机连接选型售前选型非接触雷达资料汇总定位器资料汇总

签到有奖

  • 移动端入口

  • 工业服务小程序
  • 支持中心移动端首页
  • AI小西-AI智能问答助手
  • SIEMENS工业找答案小程序
  • 工业培训与认证
  • 西门子工业1847俱乐部
  • SIEMENS工业技术支持与服务
@CurrentUser.EmailCount@

消息提醒

登录 | 注册
@CurrentUser.NickName@
1847会员:未开通
VIP等级 @CurrentUser.vipLevel@
西币
@CurrentUser.coin@
  • 我的支持中心
  • 我的1847会员
  • 我的技术论坛
  • 我的找答案
  • 我的下载中心
  • 我的售后服务
  • 我的培训认证
  • 我发的帖子
  • 我跟的帖子
  • 我的论坛设置
  • 论坛用户指南
  • 我的下载中心
  • 我的培训认证
  • 我的提问
  • 我的回答
  • 已经帮助了@CurrentUser.allAnswercount@人我要回答
  • 已连续活跃@CurrentUser.allLoginDayCount@天我要提问
  • 首次回答问题获得双倍西币积分
  • 个人设置
  • 退出
  • 首页
  • 技术支持
    • 技术支持
    • AI小西
    • 风驰卡
    • 产品入门
    • 在线产品选型
  • 售后服务
    • 售后登记和质保查询
    • 备件商城
    • ASP工程师验证
    • ASP公司证书验证
    • 售后服务常见问题
  • 下载中心
    • 首页
    • 售前文档(样本、宣传册等)
    • 售后文档(FAQ、手册等)
  • 工业学习平台
    • 首页
    • 了解会员权益
    • 立即开通1847会员
  • 培训认证
    • 首页
    • 教室培训课
    • 取证训练营
    • 在线自学课
    • 认证证书查询
    • 培训伙伴验证
  • 技术论坛
    • 首页
    • 最新发帖
    • 精华帖
    • 发新帖
  • 找答案
    • 首页
    • 已解决问题
    • 精华常见问题
    • 发布新问题

官方商城

  • 西门子中国
  • 技术支持与服务首页
    我的支持中心
    下载中心首页
    全球技术资源
    1847工业学习平台
    产品入门新手必读
    找答案
    技术论坛
    售后服务
    网络资源新手必读
    高级搜索
  • 技术论坛
    论坛公告
    论坛使用指南
    最新发帖
    精华帖
    分享帖
    高赞帖
    热门帖
    高端推荐帖
    最高收藏帖
  • 咱工程师的故事 / 网友专栏
  • 「年终技术工作笔记」父FB与其内被调用的多个子FB间的数据解耦

技术论坛

 • 产品分类
自动化系统
  • SIMATIC S7-1500系列 
  • SIMATIC S7-1200系列 
  • SIMATIC S7-200
  • SIMATIC S7-200 SMART 
  • SIMATIC S7-300/400 
  • 通信与网络组件
  • Profinet技术开发专区
  • 工业边缘计算
  • SIMATIC WinCC / Panel 
  • SIMATIC WinCC OA (原PVSS)
  • DCS/SIMATIC PCS7
  • IPC/PG
  • LOGO!
  • 物联网(IOT)
  • 工业电源
驱动技术
  • SINAMICS 
  • SINAMICS S200 
  • 直流调速器
  • 电机
  • SIMOTION
  • MicroMaster
  • 驱动技术综合产品
  • MasterDrives 
  • DCMA 变频器健康管家 维护智库
数控系统
  • SINUMERIK 
  • SIMODRIVE
低压电气
  • 低压电气
  • 低压数字化
传感器与通讯
  • 过程仪表
  • 分析仪器
  • 工厂传感器
谈天说地
  • 谈天说地
 • 咱工程师的故事
咱工程师的故事
  • 网友专栏 
  • 工程师随笔
1847大咖专栏
  • 崔工谈博途与PLC
  • PROFINET工业通信详解
  • 冯工聊工业网络
  • 电磁兼容问题及处理
  • 大咖专栏合集
特别专题
  • 专家大讲堂课后探讨
  • 西门子工业1847俱乐部
  • 特别专题合集
 • 培训与认证答疑专区
培训与认证答疑专区
  • PLC编程精英训练营
  • MA 小型自动化系统
  • WinCC系统开发工程师精英训练营
  • V90精英训练营
  • WinCC精英训练营
  • S7-1200精英训练营
  • G120变频器精英训练营
  • S7-200SMART精英训练营
 • 服务合作伙伴专区
服务合作伙伴专区
  • FA合作伙伴共创社区
  • Networks and Communication
  • GMC蓝黄带考试-G120
  • GMC蓝黄带考试-V90
  • GMC 合作伙伴专区

故事作者:'Razor论坛推荐作者

最近创作

看看TA的故事

「年终技术工作笔记」父FB与其内被调用的多个子FB间的数据解耦

'Razor

西门子1847工业学习平台

  • 帖子

    3402
  • 精华

    43
  • 被关注

    228

论坛等级:至圣

注册时间:2008-03-31

钻石 钻石 如何晋级?

「年终技术工作笔记」父FB与其内被调用的多个子FB间的数据解耦

42

0

2026-01-23 22:14:17

在做实验搞一个简单电机控制块时,突然成心地想把它写得复杂一些,又成心地赶时髦想容易“复用“容易”扩展“容易修改等容易XX系列,于是也想起了XXX和XXX认为很深不可测的东西,我觉得也就那么回事儿,不知是我看不懂还是咋着,想起来了,就干脆写一写吧,写出来大家都看看,评评。

不啰嗦,大体结构就是弄了个父FB,暂且称之为FB_0,在FB_0中又以多重实例的模式调用了多个子FB,暂且称之为FB_1,FB_2,FB_3,至于父与子的,仅表示层级结构,没有任何生物学上的关系。

FB_0内的代码呢,按照功能(命名控制、故障检测、状态机等)划分”打包“成FB_1,FB_2,FB_3,而它们又使用FB_0管脚中不同管脚的组合作为各自的参数;为了让FB_1,FB_2,FB_3可以在不同的电机类型FB中复用,应该如何处理?

我们通常将这种一个功能块(FB)调用其他多个功能块,并且这些被调用的功能块共享调用者FB的接口参数的情况,称为“共享耦合”或“公共耦合”。就像戴胜鸟头顶的毛,你用我用它也用,谁知道谁用的是哪**?它不就臭了?你严肃点儿!


在软件工程中,耦合是指模块之间相互依赖的程度。公共耦合指的是多个模块共享同一个全局数据区(或同一数据项)。在这里,FB_1, FB_2, FB_3都直接使用了FB_0的接口参数,这意味着它们都依赖于FB_0的接口,形成了较高的耦合。

具体来说,这种耦合可能导致以下问题:

可维护性差:如果FB_0的接口发生变化,那么FB_1, FB_2, FB_3都可能需要修改。

可读性差:因为多个FB都直接使用FB_0的接口,所以很难理解每个FB具体使用了哪些数据,以及如何使用的。

难以复用:这些FB因为依赖于FB_0的接口,所以很难在其他上下文中复用。

解决这种耦合的方法通常是降低模块之间的依赖,具体可以采取以下措施:

封装数据:将共享的数据封装成一个独立的FB或数据结构,然后通过参数传递的方式传递给FB_1, FB_2, FB_3,而不是让它们直接访问FB_0的接口。

接口最小化:确保每个FB只接收它所需的最小数据子集,而不是整个FB_0的接口。即,每个被调用的FB应该有自己的接口,只包含它需要的数据。

使用局部变量:在FB_0中,将需要传递给其他FB的数据先赋值给局部变量,然后通过局部变量传递,而不是直接传递整个接口。

依赖注入:通过参数传递的方式将所需的数据传递给每个FB,这样每个FB就不直接依赖于FB_0的接口,而是依赖于传递给它们的参数。

举例说明:

假设FB_0有一个输入接口Input和一个输出接口Output,而FB_1, FB_2, FB_3都直接使用了Input和Output中的一些元素。

改进方法:

我们可以为每个被调用的FB定义专门的输入输出参数,然后在FB_0中调用它们时,只传递它们所需的数据。

例如,FB_1只需要Input.A和Output.B,那么FB_1的接口就定义为:
Input: A (类型)
Output: B (类型)

在FB_0中,调用FB_1时,将Input.A传递给FB_1的输入,将FB_1的输出赋值给Output.B。

这样,FB_1就不再依赖于FB_0的整个接口,而只依赖于自己需要的部分。如果FB_0的接口发生变化,只要FB_1所需的部分不变,FB_1就不需要修改。

另外,如果FB_1, FB_2, FB_3之间有共享的数据,可以考虑将这些共享数据封装成一个结构体,然后通过参数传递。但要注意,如果封装的结构体过大,也可能导致不必要的依赖。

总之,解决这种耦合的关键是让每个模块只依赖于它所需的最小数据集合,而不是一个庞大的共享接口。

说人话就是,把大包里的东西,分别按需要拆成小包,然后再分给每个使用者。


就是,薅几**安在它头上,


再薅几**安在它头上,

可以把这种操作戏称为“植毛”!



    说到底,还是现在的REF_TO不给力啊,哪天REF_TO_FB解开了封印,也就不用“植毛”了。

    大家看看,能够笑笑就可以了。

剩余80%未阅读, 请登录阅读

回帖加入探讨技术论坛守则

上传附件要求

1. 文件大小:上传文件的大小请限制在2M以内。

2. 文件格式:请不要上传.exe文件,系统支持的格式有:
.avi,.wmv,.mp3,.rar,.zip,.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf,.wma,.asf,.txt,.7z

 
发分享帖
爱工控,乐分享,
分享您的经验与案例
发故事
发表您的精彩故事,
参与征文活动
技术探讨帖
阐述您的观点,
表达我的看法
西家杂谈
海侃天南地北,
闲聊工控世界
发求助帖
求道解惑,“刨根问底”
解决问题
发投票帖
邀投票,做调查,
网友帮您来作主
取消原因:
「年终技术工作笔记」父FB与其内被调用的多个子FB间的数据解耦
编辑推荐: 关闭

请填写推广理由:

活动公告 查看全部公告>

标准机型应用中心:让工业自动化落地更简单、价值更凸显!

1,852,064 条
海量精彩技术内容

100,000+ 网友与你交流

助你技有所长,论有所获

热门视频,猜你喜欢

本版热门话题

网友专栏

共有3384条技术帖

更多

评选标准

相关推荐

换一换

热门标签

换一换

相关帖子推荐

换一换
正在加载...
guzhang

恭喜,你发布的帖子

被评为精华帖!

快扫描右侧二维码晒一晒吧!

再发帖或跟帖交流2条,就能晋升VIP啦!开启更多专属权限!

  • 分享

  • 只看
    楼主

top

下载中心

  • 首页
  • 查找文档
  • 常见问题大全
  • 精选主题
  • 全球技术资源

  • 首页
  • 知识库
  • 订阅文档

1847工业学习平台

  • 首页
  • 了解会员权益
  • 立即开通1847会员
  • 课程中心
  • 学习路线
  • 初级工程师认证
  • 高级工程师认证

培训与认证

  • 首页
  • 教室培训课
  • 取证训练营
  • 在线自学课
  • 认证证书查询
  • 培训伙伴验证

技术论坛

  • 首页
  • 发帖
  • 最新发帖
  • 精华帖
  • 高赞贴
  • 当前热门帖
  • 高端推荐帖
  • 用户荣誉榜

找答案

  • 首页
  • 提问
  • 精华问答
  • 高赞问答
  • 新解决问题
  • 待解决问题
  • 总积分排行榜

售后服务

  • 我要报修
  • 服务进度查询
  • 质保及权益查询
  • 备件商城
  • ASP工程师验证
  • ASP公司证书验证
  • 支持中心网站重要声明

西门子中国   © 西门子(中国)有限公司 1996 – 2026   企业信息    隐私政策   使用条款   京ICP备06054295号   京公网安备 11010502040638号
 
支持中心新发布“关注”功能了!实时查看彼此动态,更方便地进行技术交流。
不管是“关注”与“被关注”,相信都是一个美好的开始!
还有多重奖励派送,快快行动起来吧!

20秒帮我们优化支持中心!

欢迎您访问支持中心!

丰富的视频,全方位的文档,大量的网友交流精华……

为了更好的完善这些内容,我们诚邀您在浏览结束后,花20秒左右的时间,完成一个用户在线调查!

感谢您的支持!

您收到0封站内信:
×
×
图片
立即
签到
已签到
已签到0天
累计可抽西币次数:0次抽奖机会
累计可抽惊喜实物奖次数:0次抽奖机会
信息提示
很抱歉!您所访问的页面不存在,或网址发生了变化,请稍后再试。