远指针

更新时间:2023-12-27 01:47

远指针不是让编译程序把程序数据段地址作为指针的段地址部分,而是把指针的段地址与指针的偏移量直接存放在指针内。

简介

因此,远指针是由4 个字节构成。它可以指向内存中的任一目标,可以用于任一编译模式,尽管仅在紧凑、大和巨模式下远指针才是缺省的数据指针。因为远指针的段地址在指针内,熟悉80X86 汇编语言的人都知道,这意味着每次使用远指针时都需要重新装载段寄存器,这显然会降低速度

区别

近指针是16位的指针,它只表示段内的偏移地址,因而只能对64k字节数据段内地址进行存取。

如 char near *p;

p=(char near *)0xffff;

远指针是32位指针,它表示段地址:偏移地址,如定义远程指针p指向B500段的2号地址,即B500:0002,则可写作:

char far *p;

p=(char far *)0xB5000002;

因此,远指针可以进行跨段寻址,可以访问整个内存的地址。

注意事项

尽管远指针可以寻址内存中的任一单元,但它所寻址的目标也不能超过64K 字节。这是因为,远指针在增量或减量之类的算术运算时,也只是偏移量部分参与运算,而段地址保持不变。因此,当远指针增量或减量到超过64K字节段边界时就出错。例如: char far *fp=(char far *)0xb800ffff;fp++; 在指针加1以后,fp将指向B800:0000,而不是所希望的C800:0000。

此外,在进行指针比较时,far指针还会引起另外一些问题。far指针是由偏移量和段地址这样一对16位数来表示的,对于某一实际内存地址,far指针不是唯一的,例如,far指针1234:0005、1230:0045、1200:0345、1000:2345、0900:9345等都是代表实际地址12345,这样会引起许多麻烦。

第一,为了便于与“空”(NULL)指针(0000: 0000)进行比较,当

关系操作符“==”和“!=”用于对far 指针进行比较时,比较的是全

部32位。否则,如果只比较16位偏移量,那么任何偏移量为0 的指针

都将是“空”(NULL)指针,这显然不符合一般使用要求。但在进行这

32位比较时,不是按20位实际地址来比较,而是把段地址和偏移量当

作一个32位无符号长整数来比较。对于上面这个例子,假设这些指针

分别叫作a、b、c、d、e,尽管这5个far 指针指向的都是同一内存单

元,但下列表达式运算的结果却都为“假”,从而得出错误的结论:

if(a==b)....

if(b==c)....

if(c==d)....

if(d==e)....

if(a==c)....

if(a==d)....

第二,当用“>”、“>=”,“<”和“<=”关系操作符对指针进

行比较操作时,比较的仅仅是偏移量部分,即按无符号的16位整数进

行比较。因此,对于上面这个例子,下列表达式运算的结果将都为

“真”,也得出错误的结论:

if(e>d)....

if(d>c)....

if(c>b)....

if(b>a)....

if(e>a)....

免责声明
隐私政策
用户协议
目录 22
0{{catalogNumber[index]}}. {{item.title}}
{{item.title}}