这是一个常见的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...