有一段代码如下:
In: Index DInt
Data Real
STANT: Store Arry[0..9]of Real
------------------------------------------------
L #Index
L 1
- I
SLD 5
L P##Store
+D
LAR1
L #Data
T DID[AR1,P#0.0]
麻烦说一下,每一句的注释,最终寄存器间接寻址的最终结果,即【AR1,P#0.0】里合并的最终结果
还有特别解释一下 L P##Store 这句话,为什么就可以表明是在用寄存器区间寻址,因为仿真的时候看到了,单独写一句 L P##Store 累加器1的数值是85000000,表明指针指向了DI,背景数据块,对这句话不能理解,以后如果自己想的话,肯定写步出来????
麻烦各位,解释一下其中的道理,越详细越好
最佳答案
L #Index //装载数组的下标
L 1 //装载 1
- I // #Index-1;因为 Arry[0] 的存储的第一个字节的地址为基地址;
SLD 5 //一般在资料中看到的是 SLD 3,
这样的写法, 因寻址的是实数空间,每个实数占用 4 个字节;
通常,SLD 3 是将常数指针化,左移 3 位后再左移 2 位,
就形成了4字节寻址的指针,两个合并起来就是 SLD 5;
比如,INDEX=2时,此时得到的是相对于基地址的指针偏移量;
L P##Store //装载 Arry[0] 的存储在DB中的第一个字节的地址
+D //与上面的偏移量相加,得到 Arry[Index-1] 这个变量存储的起始地址指针
LAR1 //将上面的地址指针存在 AR1 中
L #Data //装载要存储的数据,在接口中没有看到这个数据,
这个数据应该是实型的。
T DID[AR1,P#0.0] //将数据存放到 Arry[Index-1]
总结:
程序功能是:将传送到接口 DATA 中的实数存放到,数据块的 Arry[Index-1] 位置。
参考资料
S7-300和S7-400寻址 ID:79632832 2013年9月12日
https://support.industry.siemens.com/cs/document/79632832
使用间接寻址编写循环程序 ID:19345564发布日期 2007年3月1日
https://support.industry.siemens.com/cs/document/19345564
用于S7-300 和S7-400 的语句表(STL)编程 文档编号 1008 2008-11-13
http://www.ad.siemens.com.cn/download/docMessage.aspx?Id=1818
提问者对于答案的评价:
谢谢你的详细解答。如果将这几句代码写在FB1中,FB1的背景数据块为DB1,最终存储的数据就是在DB1里边吗?
最后的一句"T DID[AR1,P#0.0]",DI是存储区域符,表明是背景数据块,D是存储区域尺寸符吗?也就是D代表双字,4个字节的意思?这样理解对吗?
还有在Index=1时,最后一句可以写成"T DID[0.0]";Index=2时,最后一句可以写成"T DID[4.0]";Index=3时,最后一句可以写成"T DID[8.0]";Index=4时,最后一句可以写成"T DID[8.0]",这样理解对吗?
这个最后一句,是否决定了,数据最终存储的DB块编号,还有在DB块中存储的最终位置?
最佳答案作者回复:
对评价的回答
1、是在DB1中
2、第二问,理解的对。
3、Index=1时,最后一句可以写成"T DID[0.0],这样理解不对。
4、最后一句决定不了数据块的编号,只决定存储在数据块中的位置,应该还有程序指明是哪个块,另外在这的复有字数限制,多写不了。
5、建议看上面的资料
原创文章,作者:ximenziask,如若转载,请注明出处:https://www.zhaoplc.com/plc347828.html