程式定位

程式定位

程式定位一般指某一列數據的位置。

基本介紹

  • 中文名:程式定位
  • 代碼量:5~10K
  • 意義:某一列數據的位置
  • 定位程式段
程式定位,常見數組定位,

程式定位

用Keil做芝婚慨51的開發也4年多了,代碼量基本上 維持在5~10K左右,說大不大,說小也不小,也就是箇中等貨色。
這段期間工作上難得有稍許的空間,潛心研究了一下keil中如何在 CODE中定位C程式的方法。
在彙編中數勸記據段和程式段都比較容易定位,例如程式1:
cseg at 0x0000 ljmp main dseg at 0x20 aa: ds 1 iseg at 0xC0 bb: ds 1 xseg at 0x0010 cc: ds 1 cseg at 0x1000 main: mov aa,#0 sjmp main END 這段代歸槓應碼就把蒸雅重main定位到0x1000的位置。aa 定位在data(0x20)中,bb定位在idata(0xc0)中,CC定位趨剃厚到xdata(0x0010)當然,cc在不超過256位元組的時候還可以用 page方式訪問。
在C語言程式裡面定位比較複雜。

常見數組定位

1、使用 _at_
#include <reg51.h>
unsigned char data sysTemp_aa[20] _at_ 0x20; //在data段中0x20開始的地方定義一個20位元組數組
unsigned char idata sysTemp_bb[20] _at_ 0x80; //在idata段中0x80開始的地方定義一個20位元組數組
unsigned char pdata sysTemp_cc[20] _at_ 0x0000; //在pdata段中0x00開始的地方定義一個20位元組數組
unsigned char xdata sysTemp_dd[20] _at_ 0x0100; //在xdata段中0x0100開始的地方定義一個20位元組的數組
void main()
{
sysTemp_aa[0] = 0x55;
sysTemp_bb[0] = 0x55;
sysTemp_cc[0] = 0x55;
sysTemp_dd[0] = 0x55;
while(1)
{
;
}
}
編譯後生成的彙編代碼如下:
C:0x0000 020015 LJMP C:0015
11: void main() 12: {
13: sysTemp_aa[0] = 0x55; C:0x0003 752055 MOV sysTemp_aa(0x20),#0x55
14: sysTemp_bb[0] = 0x55;
C:0x0006 7880 MOV R0,#sysTemp_bb(0x80)
C:0x0008 7655 MOV @R0,#0x55
15: sysTemp_cc[0] = 0x55;
C:0x000A 7800 MOV R0,#sysTemp_cc(0x00)
C:0x000C 7455 MOV A,#0x55
C:0x000E F2 MOVX @R0,A
16: sysTemp_dd[0] = 0x55; 17:
C:0x000F 900100 MOV DPTR,#sysTemp_dd(0x0100)
C:0x0012 F0 MOVX @DPTR,A
18: while(1)
C:0x0013 80FE SJMP C:0013
C:0x0015 787F MOV R0,#0x7F
C:0x0017 E4 CLR A
C:0x0018 F6 MOV @R0,A
C:0x0019 D8FD DJNZ R0,C:0018
C:0x001B 758193 MOV SP(0x81),#0x93
C:0x001E 020003 LJMP main(C:0003)
請注意加橫線的是彙編代碼對應的C程式。
更深入一 點,如果我想把main函式定位呢?上面的彙編代碼是由keil自動定位的一個地址,添加或者刪除程式後,main的地址是不確定的,能否在也使用 _at_呢?答案紙戀嘗汽是否定的。要想把程式段絕對定位需要在keil裡面採用遙愉達項一定的設定。
例如程式3:
#include <reg51.h>
unsigned char data sysTemp_aa[20] _at_ 0x20;
unsigned char idata sysTemp_bb[20] _at_ 0x80;
unsigned char pdata sysTemp_cc[20] _at_ 0x0000;
unsigned char xdata sysTemp_dd[20] _at_ 0x0100;
extern void test1();
void main()
{
sysTemp_aa[0] = 0x55;
sysTemp_bb[0] = 0x55;
sysTemp_cc[0] = 0x55;
sysTemp_dd[0] = 0x55;
while(1)
{
test1();
}
}
void test1()
{
unsigned char i;
for(i=0;i<100;i++)
{
;
}
}
15: sysTemp_cc[0] = 0x55;
C:0x000A 7800 MOV R0,#sysTemp_cc(0x00)
C:0x000C 7455 MOV A,#0x55
C:0x000E F2 MOVX @R0,A
16: sysTemp_dd[0] = 0x55; 17:
C:0x000F 900100 MOV DPTR,#sysTemp_dd(0x0100)
C:0x0012 F0 MOVX @DPTR,A
18: while(1)
C:0x0013 80FE SJMP C:0013
C:0x0015 787F MOV R0,#0x7F
C:0x0017 E4 CLR A
C:0x0018 F6 MOV @R0,A
C:0x0019 D8FD DJNZ R0,C:0018
C:0x001B 758193 MOV SP(0x81),#0x93
C:0x001E 020003 LJMP main(C:0003)
請注意加橫線的是彙編代碼對應的C程式。
更深入一 點,如果我想把main函式定位呢?上面的彙編代碼是由keil自動定位的一個地址,添加或者刪除程式後,main的地址是不確定的,能否在也使用 _at_呢?答案是否定的。要想把程式段絕對定位需要在keil裡面採用一定的設定。
例如程式3:
#include <reg51.h>
unsigned char data sysTemp_aa[20] _at_ 0x20;
unsigned char idata sysTemp_bb[20] _at_ 0x80;
unsigned char pdata sysTemp_cc[20] _at_ 0x0000;
unsigned char xdata sysTemp_dd[20] _at_ 0x0100;
extern void test1();
void main()
{
sysTemp_aa[0] = 0x55;
sysTemp_bb[0] = 0x55;
sysTemp_cc[0] = 0x55;
sysTemp_dd[0] = 0x55;
while(1)
{
test1();
}
}
void test1()
{
unsigned char i;
for(i=0;i<100;i++)
{
;
}
}

相關詞條

熱門詞條

聯絡我們