浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
樓主  發(fā)表于: 2014-04-07 12:14
各位師傅好,我這里有一段西門子300 plc 的程序,看不太明白,望師傅不吝賜教,謝謝。
這段指針和循環(huán),不知道該怎么看?



     
[ 此帖被浮生若夢在2014-04-07 12:22重新編輯 ]
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
1樓  發(fā)表于: 2014-04-07 12:25
圖片共3 張,中間第二張圖片,跳轉(zhuǎn)標(biāo)號m003只有一個,不是截圖上的“有2個跳轉(zhuǎn)標(biāo)號m003” 不知道我這樣解釋師傅們聽明白了沒。。。。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
2樓  發(fā)表于: 2014-04-08 11:50
引用
引用第2樓sjm213于2014-04-08 09:04發(fā)表的中去  :
OB1中:
IN0=P#DB9.DBX0.0
//表示IN0處為指針,指針指向DB9.DBX0.0

FC35中:
.......

感謝版主大人的熱心回復(fù)!
另外,我這里還有些疑問,fc35,前四行語句,我的理解是:
把指針值 DB9.DBW0放到#TEMP2中去,
fc35,第五,六,行語句,是將 DB9.DBD2裝載到地址寄存器AR1中去,
fc35,第七行語句,是打開數(shù)據(jù)塊 DB9.DBW0,但這樣理解好像也不對。
我對300的指針這塊還是不理解。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
3樓  發(fā)表于: 2014-04-08 15:25
再次謝謝版主,
關(guān)于指針這塊,我再研究下,有問題時,還得請教您,謝謝。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
4樓  發(fā)表于: 2014-04-10 12:30
引用
引用第4樓sjm213于2014-04-08 13:01發(fā)表的  :
前四行是把“9”這個數(shù)放到#TEMP2中,所以第七行的OPN DB[#TEMP]實際上就是打開數(shù)據(jù)塊DB9;
五、六行指針指向DBX0.0,而不是DBX2.0(這個DBX0.0是從OB1調(diào)用FC35塊時的P#DB9.DBX0.0得來的)。
看指針的數(shù)據(jù)結(jié)構(gòu):
[attachment=119802]


版主請看,我這樣的理解對嗎?
另外我還是想不明白,累加器和地址寄存器都是32位的,它們怎么能裝得下48位的pointer 類型的數(shù)據(jù)呢?
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
5樓  發(fā)表于: 2014-04-10 12:37

另外,我這里還有以前自己分析過的一段程序,對于程序中指針部分的理解,總感覺有問題,還望版主大人指教,在這里先說聲,謝謝了,謝謝版主大人耐心解答,才使得我們這樣的新手少走彎路。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
6樓  發(fā)表于: 2014-04-10 20:14
引用
引用第8樓lichenhui333于2014-04-10 13:50發(fā)表的  :
里面不會出現(xiàn)6個字節(jié)的,當(dāng)裝載雙字時,ACUU1里面的原有內(nèi)容自動轉(zhuǎn)存到ACUU2里面去了。ACUU2里面原有內(nèi)容被覆蓋。這樣ACUU1里面的就裝載雙字了。

pointer類型的數(shù)據(jù)是直接裝載到 ACCU1中去的,但 ACCU1是32位,pointer類型數(shù)據(jù)是48位啊。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
7樓  發(fā)表于: 2014-04-13 21:41
引用
引用第11樓zhangdingye于2014-04-13 16:49發(fā)表的  :
哥們  你的程序是怎么從電腦上面 弄下來的   不是 復(fù)制粘貼不行嗎

截圖,這些程序都是圖片形式的。
浮生若夢
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
8樓  發(fā)表于: 2014-04-14 15:54
引用
引用第14樓757480856于2014-04-14 14:28發(fā)表的  :
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
發(fā)帖數(shù)量: 61 個
工控威望: 200 點
下載積分: 2395 分
在線時間: 86(小時)
注冊時間: 2013-05-28
最后登錄: 2017-12-31
查看浮生若夢的 主題 / 回貼
9樓  發(fā)表于: 2014-04-14 22:01
謝謝樓上的師父,謝謝您的熱心解答。