浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
楼主  发表于: 2014-04-07 12:14
各位师傅好,我这里有一段西门子300 plc 的程序,看不太明白,望师傅不吝赐教,谢谢。
这段指针和循环,不知道该怎么看?



     
[ 此帖被浮生若梦在2014-04-07 12:22重新编辑 ]
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
1楼  发表于: 2014-04-07 12:25
图片共3 张,中间第二张图片,跳转标号m003只有一个,不是截图上的“有2个跳转标号m003” 不知道我这样解释师傅们听明白了没。。。。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
2楼  发表于: 2014-04-08 11:50
引用
引用第2楼sjm213于2014-04-08 09:04发表的中去  :
OB1中:
IN0=P#DB9.DBX0.0
//表示IN0处为指针,指针指向DB9.DBX0.0

FC35中:
.......

感谢版主大人的热心回复!
另外,我这里还有些疑问,fc35,前四行语句,我的理解是:
把指针值 DB9.DBW0放到#TEMP2中去,
fc35,第五,六,行语句,是将 DB9.DBD2装载到地址寄存器AR1中去,
fc35,第七行语句,是打开数据块 DB9.DBW0,但这样理解好像也不对。
我对300的指针这块还是不理解。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
3楼  发表于: 2014-04-08 15:25
再次谢谢版主,
关于指针这块,我再研究下,有问题时,还得请教您,谢谢。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
4楼  发表于: 2014-04-10 12:30
引用
引用第4楼sjm213于2014-04-08 13:01发表的  :
前四行是把“9”这个数放到#TEMP2中,所以第七行的OPN DB[#TEMP]实际上就是打开数据块DB9;
五、六行指针指向DBX0.0,而不是DBX2.0(这个DBX0.0是从OB1调用FC35块时的P#DB9.DBX0.0得来的)。
看指针的数据结构:
[attachment=119802]


版主请看,我这样的理解对吗?
另外我还是想不明白,累加器和地址寄存器都是32位的,它们怎么能装得下48位的pointer 类型的数据呢?
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
5楼  发表于: 2014-04-10 12:37

另外,我这里还有以前自己分析过的一段程序,对于程序中指针部分的理解,总感觉有问题,还望版主大人指教,在这里先说声,谢谢了,谢谢版主大人耐心解答,才使得我们这样的新手少走弯路。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
6楼  发表于: 2014-04-10 20:14
引用
引用第8楼lichenhui333于2014-04-10 13:50发表的  :
里面不会出现6个字节的,当装载双字时,ACUU1里面的原有内容自动转存到ACUU2里面去了。ACUU2里面原有内容被覆盖。这样ACUU1里面的就装载双字了。

pointer类型的数据是直接装载到 ACCU1中去的,但 ACCU1是32位,pointer类型数据是48位啊。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
7楼  发表于: 2014-04-13 21:41
引用
引用第11楼zhangdingye于2014-04-13 16:49发表的  :
哥们  你的程序是怎么从电脑上面 弄下来的   不是 复制粘贴不行吗

截图,这些程序都是图片形式的。
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
8楼  发表于: 2014-04-14 15:54
引用
引用第14楼757480856于2014-04-14 14:28发表的  :
2楼回答的是正解,pointer指针在fc块中的使用时必须拆分,在该程序中:

L P##IN0                             //装载pointer指针
  LAR1                                  //至AR1
  L W[AR1,P#0.0]                 //该句是装载48位pointer中的前16位,即byte n,byte n+1,也就是DB块号(该例子中为9),这里就在拆分pointer指针中的信息
.......

师父您好,您说的这些我大概都明白了。
麻烦您再看看我7楼的程序,我的理解对吗?我怎么总感觉理解有问题?
浮生若梦
级别: 略有小成
精华主题: 0
发帖数量: 61 个
工控威望: 200 点
下载积分: 2395 分
在线时间: 86(小时)
注册时间: 2013-05-28
最后登录: 2017-12-31
查看浮生若梦的 主题 / 回贴
9楼  发表于: 2014-04-14 22:01
谢谢楼上的师父,谢谢您的热心解答。