間接尋址是指用指針來訪問存儲區的數據。指針以雙字的形式存儲其它存儲區的地址,隻能將V存儲單元、L存儲單元或累加寄存器(AC1、AC2、AC3)用作指針。
創建指針時,必須使用“移動雙字”指令,將間接尋址的存儲(chu) 單元地址移至指針位置。;用“&”符號加上要訪問的存儲(chu) 區地址可建立一個(ge) 指針,當指令中的操作數是指針時,應該在操作數前加上“*”號。
1.建立指針
建立指針記得加“&”;將VB100的地址存放到VD1000內(nei) 。
2.指針偏移按字節尋址,就+1;
按字尋址,就+2;
按雙字或浮點數尋址,就+4;
3.取指針 4.程序監控 1)按下M0.0,執行字節偏移,此時在VB101輸入“10”,VB3000的數據即為“10”,然後複位M0.0。2)按下M0.1,執行字偏移,此時在VW102輸入“50”,VW4000的數據即為“50”,然後複位M0.1。3)按下M0.2,執行雙字偏移,此時在VD104輸入“80”,VD5000的數據即為“80”,然後複位M0.2。程序實例(幹貨)
實例1:通過指針間接尋址改變定時器的3種不同定時時間。
實例2:通過指針間接尋址找一組數據的最值(大和小)和平均值。主程序
子程序
程序的監控圖就不貼出來了,其實重點就在子程序的第二段,每循環一次,就做一次比較,如果比較條件滿足,就將大值和小值暫存到LD10和LD14中,直到循環到最後一次,此時最大值和最小值已經找出來了,平均值就是將每循環一次的值進行累加,然後再除以數據個(ge) 數,這裏我就不展開仔細的分析了,可以參考一下最後一個(ge) 案例,冒泡排序執行原理。
實例3:通過指針間接尋址改變5個計數器的計數值。案例4,冒泡排序,從(cong) 小排到大。
主程序,排8組數據。
子程序
冒泡排序算法解析:
八組數據:分別是20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8。
1.首先將要排列的數據個(ge) 數-2(8-2),然後存放到LW10中;再將這個(ge) 值附給外循環的FINAL。
2.第一個(ge) 外循環的執行的次數即為(wei) 0~6(7次)。
3.INDX:假定 INIT 值為(wei) 0,FINAL 值為(wei) 6,則 FOR 指令和 NEXT 指令之間的指令將執行 7 次,INDX 值遞增:0,1, 2, 3, 4.5.6。
第一次外循環(執行7次內(nei) 循環)
第一次內(nei) 循環
20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8;(20.0<365.0,位置不變)
第二次內(nei) 循環
20.0;7.0;365.0;7.0;210.5;7.6;15.6;22.8;(7.0<365.0,位置改變)
第三次內(nei) 循環
20.0;7.0;7.0;365.0;210.5;7.6;15.6;22.8;(7.0<365.0,位置改變)
第四次內(nei) 循環
20.0;7.0;7.0;210.5;365.0;7.6;15.6;22.8;(210.5<365.0,位置改變)
第五次內(nei) 循環
20.0;7.0;7.0;210.5;7.6;365.0;15.6;22.8;(7.6<365.0,位置改變)
第六次內(nei) 循環
20.0;7.0;7.0;210.5;7.6;15.6;365.0;22.8;(15.6<365.0位置改變)
第七次內(nei) 循環
20.0;7.0;7.0;210.5;7.6;15.6;22.8;365.0;(22.8<365.0位置改變,找到最大值),即最大值365.0。
第二次外循環(執行6次內(nei) 循環)
第一次內(nei) 循環
7.0;20.0;7.0;210.5;7.6;15.6;22.8;365.0;(7.0<20.0,位置改變)
第二次內(nei) 循環
7.0;7.0;20.0;210.5;7.6;15.6;22.8;365.0;(7.0<20.0,位置改變)
第三次內(nei) 循環
7.0;7.0;20.0;210.5;7.6;15.6;22.8;365.0;(20.0<210.5,位置不變,接下來就是210.5跟後麵的數進行比較)
第四次內(nei) 循環
7.0;7.0;20.0;7.6;210.5;15.6;22.8;365.0;(7.6<210.5,位置改變)
第五次內(nei) 循環
7.0;7.0;20.0;7.6;15.6;210.5;22.8;365.0;(15.6<210.5,位置改變)
第六次內(nei) 循環
7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(22.8<210.5,位置改變,找到第二個(ge) 值),即第二大值210.5。
第三次外循環(執行5次內(nei) 循環)
第一次內(nei) 循環
7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(7.0=7.0,這裏的排序就不變,假設第一個(ge) 值為(wei) 8.0,8.0>7.0,則位置改變)
第二次內(nei) 循環
7.0;7.0;20.0;7.6;15.6;22.8;210.5;365.0;(7.0<20.0,位置改變)
第三次內(nei) 循環
7.0;7.0;7.6;20.0;15.6;22.8;210.5;365.0;(7.6<20.0,位置改變)
第四次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(15.6<20.0,位置改變)
第五次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(20.0<22.8,位置不變,找出第三個(ge) 值),即第三大值22.8。
第四次外循環(執行4次內(nei) 循環)
第一次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變)
第二次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變)
第三次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.6<15.6,位置不變)
第四次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(15.6<20.0,位置不變,找出第四個(ge) 值),即最第四大值20.0。
第五次外循環(執行3次內(nei) 循環)
第一次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變)
第二次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變)
第三次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.6<15.6,位置不變,此時找出第五個(ge) 值),即第五大值15.6。
第六次外循環(執行2次內(nei) 循環)
第一次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變)
第二次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0<7.6,位置不變,此時找出第六個(ge) 值),即第六大值7.6。
第七次外循環(執行1次內(nei) 循環)
第一次內(nei) 循環
7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0;(7.0=7.0,位置不變,此時找出第七個(ge) 值),即第七大值7.0。
那麽(me) 最後的那個(ge) 數顯然就是最小值了。
最後由小到大依次排列出來的結果(7.0;7.0;7.6;15.6;20.0;22.8;210.5;365.0)。
其實這是一種冒泡排序法,熟悉計算機語言的小夥(huo) 伴就應該比較了解這種算法,至於(yu) 冒泡算法的具體(ti) 原理和說明,請各位小夥(huo) 伴自行百度一下,這裏就不再贅述了。
程序執行原理:
第一次外循環
第一次內(nei) 循環
LW8=0,AC1=0*4,AC2=0+4,AC0=0,AC2=4;LD0偏移0和4,即VD1000和VD1004做比較(>),由於(yu) VD1000=20.0不大於(yu) VD1004=365.0;則程序6不執行,排序不改變(即20.0;365.0;7.0;7.0;210.5;7.6;15.6;22.8;)。
第二次內(nei) 循環
LW8=1,AC1=1*4,AC2=4+4,AC0=4,AC2=8;LD0偏移4和8,即VD1004和VD1008做比較(>),由於(yu) VD1004=365.0>VD1008=7.0;
則程序6執行,*AC1(VD1004=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1008=7.0)把值傳(chuan) 給*AC1(VD1004=7.0),最後將TEMP的值傳(chuan) 給*AC2(VD1008),此時VD1004=7.0,VD1008=365.0,排序發生變化(即20.0;7.0;365.0;7.0;210.5;7.6;15.6;22.8;)。
第三次內(nei) 循環
LW8=2,AC1=2*4,AC2=8+4,AC0=8,AC2=12;LD0偏移8和12,即VD1008和VD1012做比較(>),由於(yu) VD1008=365.0>VD1012=7.0,則程序6執行,*AC1(VD1008=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1012=7.0)把值傳(chuan) 給*AC1(VD1008=7.0),最後將TEMP的值傳(chuan) 給*AC2(VD1012),此時VD1008=7.0,VD1012=365.0,排序發生變化(即20.0;7.0;7.0;365.0;210.5;7.6;15.6;22.8;)。
第四次內(nei) 循環
LW8=3,AC1=3*4,AC2=12+4,AC0=12,AC2=16;LD0偏移12和16,即VD1012和VD1016做比較(>),由於(yu) VD1012=365.0>VD1016=210.5,
則程序6執行,*AC1(VD1012=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1016=210.5)把值傳(chuan) 給*AC1(VD1012=210.5),最後將TEMP的值傳(chuan) 給*AC2(VD1016),此時VD1012=210.5,VD1016=365.0,排序發生變化(即20.0;7.0;7.0;210.5;365.0;7.6;15.6;22.8;)。
第五次內(nei) 循環
LW8=4,AC1=4*4,AC2=16+4,AC0=16,AC2=20;LD0偏移16和20,即VD1016和VD1020做比較(>),由於(yu) VD1016=365.0>VD1020=7.6,
則程序6執行,*AC1(VD1016=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1020=7.6)把值傳(chuan) 給*AC1(VD1016=7.6),最後將TEMP的值傳(chuan) 給*AC2(VD1020),此時VD1016=7.6,VD1020=365.0,排序發生變化(即20.0;7.0;7.0;210.5;7.6;365.0;15.6;22.8;)。
第六次內(nei) 循環
LW8=5,AC1=5*4,AC2=20+4,AC0=20,AC2=24;LD0偏移20和24,即VD1020和VD1024做比較(>),由於(yu) VD1020=365.0>VD1024=15.6,
則程序6執行,*AC1(VD1020=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1024=15.6)把值傳(chuan) 給*AC1(VD1020=15.6),最後將TEMP的值傳(chuan) 給*AC2(VD1024),此時VD1020=15.6,VD1024=365.0,排序發生變化(即20.0;7.0;7.0;210.5;7.6;15.6;365.0;22.8;)。
第七次內(nei) 循環
LW8=6,AC1=6*4,AC2=24+4,AC0=24,AC2=28;LD0偏移24和28,即VD1024和VD1028做比較(>),由於(yu) VD1024=365.0>VD1028=22.8,
則程序6執行,*AC1(VD1024=365.0)的值存放到TEMP裏(TEMP=365.0),然後*AC2(VD1028=22.8)把值傳(chuan) 給*AC1(VD1024=22.8),最後將TEMP的值傳(chuan) 給*AC2(VD1028),此時VD1024=22.8,VD1028=365.0,排序發生變化(即20.0;7.0;7.0;210.5;7.6;15.6;22.8;365.0;)。最後找到了最大值,此時VD1028=365.0。
下麵的循環就不在贅述,原理同上。