线下实训
HOME
线下实训
正文内容
plc编程bug太多 这是一个常见的PLC程序小BUG,你们找出来了吗? #电工
发布时间 : 2024-10-08
作者 : 小编
访问数量 : 23
扫码分享至微信

这是一个常见的PLC程序小BUG,你们找出来了吗? #电工

这是一个汇川PLC的程序,这里有一个小bug,等一下我演示给你们,看看你们能不能找到问题。

我打开一个触摸屏,这个触摸屏是在线模拟的,这是一个非常常见的小bug,很多人会在写程序的时候经常忽略,没有去检查,待会我演示给你们看。

现在我启动,看到没有,这个工位运行亮了,但是这个地方取盘位并没有点亮,原因在于前面这个set并没有on,而是一直off。我这行程序已经执行完了,因为从200已经跳到300。

列举三菱PLC编程软件GX Works2的几个坑爹BUG

三菱PLC在国内自动化行业使用非常广泛,作为经典的日系工控产品品牌之一,他留给我的印象是简单、好用、便宜(相比欧美产品),而且编程软件也由原来的GX Developer推出了更强大的GX Works2和GX Works3,除了基本的梯形图简单工程外还支持ST,FBD,SFC等高级语言结构化编程,但是可能由于时间短或者其他原因,在应用这些高级语言时却有不少让人抓狂的BUG,下面就列举一些本人发现的BUG和不足,让大家少走弯路。

声明数组起始数不为0时会出错

在标签页中声明数组标签时,勾选数组设定数量n后,会默认声明成[0..n-1],例如声明10个word数组:

但是数据类型中的(0..9)是可以编辑的,我们可以改为(1..10):

更改之后编程、编译、下载、运行都没有报错,但是他会出现一个致命的bug:数组中某个数据赋值不正确或无法赋值! 是不是很诡异, 但是这个错误不是一定出现的,只有在大量使用复杂编程的时候才有可能出现,以前项目中出现一次我找了一整天才发现原因!附上当时的异常照片:

图中程序是将bit数组Done(1..7)赋给7个bit变量,但是Done[6]的值却无法传递给其他变量,解决这个问题的方法就是将所有数组的起始号都改为0,即使0用不到,空着浪费也要声明出来。

for循环下结构体数组多层嵌套会出错

在我的蜘蛛纸牌视频中(三菱PLC编写《蜘蛛纸牌》),有一段程序就碰到了这个问题,如下图:

在这段程序中我将数组 iDownNumb[ii] 传递给 jj ,又将 jj 写入结构体的元素数组 BEHIND_LINE[ii].Numb[jj] 中,我为什么要这么写呢?我可以直接写成 BEHIND_LINE[ii].Numb[iDownNumb[ii]] 的啊,为什么要用个 jj 变量呢?原因是如果我省略 jj 将数组变量直接写入结构体元素数组中,那么这个FOR循环执行后 BEHIND_LINE[ii].Numb 中赋的值就不正确,跟等号后面的数组变量pageList 里面的值完全没有关系,我当时因为这个情况一度怀疑我是不是哪里写错了看不出来,脑袋秀逗了?弄了半天才发现问题所在,大家以后如果遇到类似的问题,先不要怀疑自己,有可能是软件比较坑爹,解决的办法就如上图所示,变量不要嵌套太多层,多用点中间变量来过度一下。

长时间编辑程序软件会崩溃

这个问题最坑爹了,写了半天的程序,终于写的差不多了想点一下编译,看看有没有错误,结果软件卡死崩溃了,关键是还没有自动保存,只能眼睁睁的看着你好不容易写了半天的程序变成浅灰色,看着那转着圈圈的鼠标和弹出的错误提示框,狠心的点下“关闭程序”。当时的心情就是:关机不干了。。。

所以在使用GX Works2时一定要养成随手点保存的良好习惯,如果你真的忘了保存且软件崩溃的话,记得及时给显示出来的程序照一张照片,能救一点是一点。

软件崩溃的时候还可能导致程序文件受损,这个就更惨了,比如网上这个人:

保存时断电导致整个程序打不开,几天的活白干了,这就太打击人了,所以重要的项目程序不仅要“保存”还要“另存”。

添加注释时程序会变“绿”

相信用过三菱ST的都遇到过这个问题吧,只要你写注释,就会大概率发生这个问题

还是刚才的蜘蛛纸牌中的程序,我只是在赋值语句后面增加一段注释,加了一行空行,程序的部分标签就变为了与注释相同的绿色,这个绿色如果只是出现在标签上影响还不太大,如果出现在基本指令或者功能函数上,很可能编译会报错。

刚开始使用GX Works的人可能会不知所措,但解决的办法很简单,点击保存按钮,颜色就会恢复正常了, 如果你不幸的遇到了不能编译的情况,你还要找到变绿的指令,保存后在后面敲击空格,或者重新输入才能解决。

低版本的软件使用ModbusTCP模块报错

ModbusTCP用的人可能不是很多,三菱的PLC需要智能模块支持,这个模块卖的很贵而且货期也长,网上资料也少,在使用这个模块时按照手册一步步配置,给400一遍遍打电话询问,但编译的时候一直报错,后来问了很多人才锁定问题出在软件版本上而不是设置上,当时三菱官网下载的中文最高版本仍然不能解决问题,后来网上各种找、给各个三菱供应商打电话找到一个英文版的才好用,现在我用的是V1.555D中文版也能够正常使用这个模块了,下载运行后模块的报警灯仍然会闪,但是不影响使用了。

下面说说三菱PLC在ST语言下的一些不足:

只能声明一维数组

三菱PLC只能声明一维数组,这对编程人员来说有了很大的限制。像西门子、倍福、施耐德都是可以声明多维数组的:

上图是西门子博图软件声明的一个三维int数组,如果三菱支持这个功能,上面蜘蛛纸牌的程序中BEHIND_LINE[ii].Numb[jj] 就不必写成结构体+数组的形式,直接写成一个二维数组BEHIND_LINE[ii,jj] 就可以了。

只能建立一层结构体

在三菱的结构体中只能声明基本类型的标签,无法声明其他的结构体,这也注定了三菱不能像施耐德和西门子那样完成复杂的逻辑功能。看一下西门子的多层结构体:

调用后是这样的:

有什么用呢?给大家看一下我们机器人控制系统的局部变量:

ROBOT结构体作为机器人核心控制程序的接口,所有的设置、状态和命令等全部包含其中,图中展示的只是其中的几个参数。

数学计算中数据类型无法自动转换

比如三菱的加法运算,我们把加号“+”用鼠标拖入程序中,看他支持的数据类型:

图中显示,加法运算支持任意类型的数字量+任意类型的数字量;那我们直接写“1+1.2”可不可以呢?

编译后显示报错,提示数据类型不一致,也就是“+”的前后必须是相同的类型,因为1是整形,1.2是浮点型,如果想要进行上面的运算,必须将1写成1.0才行。简直不可理喻啊!

word类型标签不支持按位寻址

三菱的内部软元件D是可以按位使用的,比如D0.0表示字软元件D0的第 0 位,可以当作开关量来使用。但是如果你声明一个word类型的标签,也是16位的数据类型,而且PLC会把他自动分配给D软元件缓存,但他却不支持按位使用,比如声明varTemp:word; 程序varTemp.0:=true 会报错:

可以看到varTemp.0 无法解析,不知道这是为啥。。。

其他

三菱还有一些其他的问题,比如ST编程不支持单步执行、程序断点等功能,你们还遇到过哪些问题呢?

相关问答

plc程序的bug是怎么回事?

BUG就是程序逻辑疏漏或缺陷及潜在缺陷,没有漏洞这一说。因为PLC程序不能像电脑一样打补丁而只能修改编写。BUG是电脑编程的专业术语。但PLC里一般不会用BUG这...

plc里bug是什么意思?

BUG就是程序逻辑疏漏或缺陷及潜在缺陷,没有漏洞这一说。因为PLC程序不能像电脑一样打补丁而只能修改编写。BUG是电脑编程的专业术语。但PLC里一般不会用BUG这...

西门子plc程序bug会怎么样?

西门子plc程序bug会损伤机器BUG就是程序逻辑疏漏或缺陷及潜在缺陷,没有漏洞这一说。因为PLC程序不能像电脑一样打补丁而只能修改编写。BUG是电脑编程的专业术...

plc怎么在线修改程序,就是不用停止运行就可以下载程序的?

修改完成退出run中写入模式,防止下次转换/编译直接写入,以上就是plc在线修改程序不同停止下载的方法,希望能帮到你!切记在运行中在线写入程序一定要注意动作顺序...

西门子200plc主站和从站网络通讯经常死机?

1.是的,西门子200PLC主站和从站网络通讯经常会出现死机的情况。2.这主要是由于以下原因造成的:首先,网络通讯故障可能是由于网络连接不稳定或者网络带宽不足...

PLC软件为什么自己很难下载和安装成功?

一句话来回复都是因为利益,简单一个字-钱!关于安装问题:PLC我以前安装过,都要破解这破解那,要是舍得花钱,都是正版的,哪有这么多事!因为对于每一个用户...上一...

工业自动化非标行业,编程语言现在的梯形图会被高级语言取代吗?

你好,很高兴回答你的问题,我是头条@沪A林工,电气技术领域的自媒体新人。结合我的从业经历给你作答如下。目前非标自动化行业的主流编程语言还是梯形图,由于...

电脑关机时总显示程序错误-ZOL问答

4.操作系统自身的问题,操作系统本身也会有bug。5.硬件问题,例如内存条坏了或者存在质量问题,或者内存条的金手指的灰尘特别多。应用程序错误解决方法:1.检查...

我一个女孩子,竟然对编程感兴趣,去学这个能学会吗?

肯定能。编程这东西,初学并不算特别难,应该说还算容易上手,只是越到后面精深的领域,那就比较难了。现在的相关书籍还挺多,而且还都简单易懂,比如《C语言...肯...

做电气维修的学编程语言接受会快些吗?(个人感觉这和编程逻辑...

走向社会赞了好几年的大洋和朋友合伙买了个二手电脑自学,干了这么多年的维修的有点小领悟,感觉这编程语言的思维方式相同,自学了单片机的C,电脑的php,python...

 安娜卡列琳娜  龙珠改 究极武斗传 
王经理: 180-0000-0000(微信同号)
10086@qq.com
北京海淀区西三旗街道国际大厦08A座
©2024  上海羊羽卓进出口贸易有限公司  版权所有.All Rights Reserved.  |  程序由Z-BlogPHP强力驱动
网站首页
电话咨询
微信号

QQ

在线咨询真诚为您提供专业解答服务

热线

188-0000-0000
专属服务热线

微信

二维码扫一扫微信交流
顶部