加入收藏 在线留言 联系我们
关注微信
手机扫一扫 立刻联系商家
全国服务热线15915421161
公司新闻
为何定义的FB,FC块,多次调用后程序混乱
发布时间: 2024-05-14 14:59 更新时间: 2024-11-26 07:00
六、为何定义的FB,FC块,多次调用后程序混乱?

对于,多次调用的程序块,FB块建议更换调用不同的背景DB,FC则需要确保使用的存储地址不重复,即每次调用,块中调用的地址不重复;


七、为何含有定时器或计数器的FB或FC单次调用ok,多次调用时定时器或计数器混乱?

对于多次调用的FB,FC,如为S7定时器,计数器,则需要在IN接口中定义TIMER或Counter,每调用一次FB或FC,均赋不同的定时器或计数器号,如为IEC定时器,计数器,则需要在IN接口定义Block_DB,每调用一次FB或FC,均赋不同的DB块给其中的IEC定时器或计数器;


八、临时变量引起的麻烦

临时变量可以在组织快OB、功能FC和功能块FB中使用,当块执行时它们被用来临时存储数据,一旦块执行结束,堆栈的地址将被重新分配用于其它程序块使用,此地址上的数据不会被清零,直到被其他程序块赋予新值,需要遵循“先赋值,再使用”的原则;


九、有常见的几种情况导致程序运行不正常

1、某个块程序运行时好时坏,其中某个数值或多个数值偶尔不正常。此问题在于,一定遵循“先赋值,再使用”,否则,TEMP的数值在每个扫描周期开始未有明确的赋值,此地址的数值将是随机的;


2、多个块使用TEMP,单独使用任意一个都正常,无法一起正常使用。此问题在于,TEMP未能先赋值,再使用,程序块1的TEMP中的数值并没有清零,而是CPU运行机制调用此地址使用或直接分配给程序块2使用,导致这个TEMP地址并不为0,因此程序混乱,由于内存运行机制并不公开,因此,这一分配过程看起来是随机的,这可能导致,程序多次运行情况下正常,运行一段时间后出现问题,只要遵循“先赋值,再使用”的原则,就可避免;

图片

3、TEMP无法实现自锁。此问题在于,TEMP数值无法像M点或Q点一样保持上一个周期的数值,TEMP需要在每个扫描周期有一个明确的赋值,即先赋值(写),再使用(读写),解决方式,FB可使用STAT静态变量,FC可使用M区或全局DB地址;

十、总结

在使用临时变量TEMP时:

1、不能先使用,再赋值;

2、不适用于自锁线圈;

3、不适用于上升,下降沿;

4、遇到如上情况,FC块可采用M区或全局DB地址,FB块也可采用自身背景DB的STAT静态变量,在FB,FC中使用第一次调用的某个临时变量,必须先对其赋值即写指令,而不能是读指令。


联系方式

  • 电  话:15903418770
  • 联系人:张经理
  • 手  机:15915421161
  • 微  信:15915421161