当前位置:首页 > 技术知识 > 正文内容

PLC中ST语言的几种程序流程控制语句,温故而知新吧

maynowei7个月前 (10-19)技术知识133

ST语言是IEC61131-3中规定的5中标准语言之一,ST语言的一个好处是移植性好,各家的ST语言基本都是类似的,所以如果有一个巨牛逼的算法,用ST语言实现是再好不过的了,这样可以很容易的在多个品牌的PLC上移植,当前,有个前提条件是在这个算法中不要使用太多的系统功能块,因为系统功能块往往都是各个品牌比较个性的东西,会给移植带来麻烦。另外,ST语言最适合写一些复杂的算法,个人觉得尤其是对应一些数组的操作,用ST语言是最方便的,当然有梯形图也能实现,不过远没有用ST来的方便。ST语言的语法和pascal非常像,有时候各种语言用多了,就会混,所以这里将ST语言的几种常用控制语句记录下来。

1,IF结构:

基本语法是:

IF bool_expression_1 THEN

<逻辑语句>

ELSIF bool_expression_2 THEN //这两行可选

<逻辑语句>

ElSE //这两行可选

<逻辑语句>

END_IF;

举例:

IF a>b THEN

flag:=1;

ELSIF a<b THEN

flag:=2;

ELSE

flag:=3;

END_IF;

说明:

IF语句和梯形图里的常开常闭指令类似,不太推荐用IF语句写复杂逻辑,bool逻辑还是用梯形图写起来方便也直观,除非对ST语言非常热爱同时对梯形图一点不懂。

2,FOR结构:

基本语法是:

FOR count:= initial_value TO final_value BY increment DO

<循环体>

END_FOR;

举例:

sum:=0;

FOR i:= 2 TO 100 BY 2 DO

sum:=sum+i; //计算0-100内偶数和,包含100

END_FOR;

说明:

BY可后面跟的步长是可选的,如果没有默认为1.

如果要提前退出循环,可以在循环内部增加一个判断条件,配合EXIT语句实现,如下:

FOR count:= initial_value TO final_value BY increment DO

IF bool_expression THEN

EXIT;

END_IF;

END_FOR;

3,CASE结构:

基本语法:

CASE numeric_expression OF

selector_1:

<逻辑语句>

……

selector_n:

<逻辑语句>

ELSE

<逻辑语句>

END_CASE;

举例:

CASE num OF

1,2,3:

a:=10;

4:

a:=20;

else

a:=100;

END_CASE;

说明:

CASE语句和其他高级语言中的CASE语句很类似,但是少了break,实际上这里的CASE只会执行第一个满足条件的语句,相当于在每一个选项里自动增加了一个break操作。

4,WHILE结构:

基本语法:

WHILE bool_expression DO

<逻辑语句>

END_WHILE;

举例:

i:=0;

sum:=0;

WHILE i=100 DO

sum:=sum+i;

i:=i+1;

END_WHILE;

说明:

WHILE和FOR几乎是可以通用的,随个人喜好用吧。

知识在于积累,天生异禀者有,而生而知之者不存在,更何况书山有路,学海无涯,在有限的生命里,用有限的精力去徜徉学海,百舸争流,虽苦,也不枉是一件趣事,当你征服一个又一个暗礁,躲过一个又一个激浪,待到风平浪静,旭日东升时,婉儿一笑。

与君共勉!

相关文章

Android监听滚动视图(监听页面滚动)

Android UI Libs之Android-ObservableScrollView1. 说明Android-ObservableScrollView,顾名思义,Android上观察滚动的视图,可...

C语言进阶教程:线程同步:互斥锁、条件变量与信号量

在多线程编程中,线程同步是确保数据一致性和程序正确性的关键。当多个线程需要访问共享资源时,如果缺乏适当的同步机制,就可能导致竞态条件(Race Condition)、死锁(Deadlock)等问题。本...

从 async/await 到虚拟线程:Python 并发的再思考

演进之路:从async/await到线程的反思首先必须明确的是,async/await对Python并非全无裨益:它最大的价值,是让更多人接触到了并发编程。通过在编程语言中嵌入语法元素,并发编程的门槛...

采用Oracle OSB总线进行服务注册和接入

做大型企业内部业务系统集成的应该都知道,Oracle SOA套件当前是应用广泛的一个商业集成产品套件,其中包括了OSB服务总线, BPEL业务流程引擎,BPM业务流程管理,ODI大数据服务集成,MFT...

Docker安装Oracle 11g 数据库过程详解

1、查看docker 版本[root@node3 ~]# docker version Client: Version: 18.09.6 API version:...

见招拆招:破解Oracle数据库密码(oracle数据库如何解锁)

一.概要本文主要目的,希望通过分享解密方法引起相关人士对网络安全的重视。数据库安全绝不单只数据库本身的安全,和数据库所处的整个环境都有密切关系。本文所说的破解oracle9i、oracle10g、or...