您当前的位置:首页 > 互联网教程

C语言中出现的far是什么意思

发布时间:2025-05-13 17:58:10    发布人:远客网络

C语言中出现的far是什么意思

一、C语言中出现的far是什么意思

1、近指针、远指针,这是16位CPU造就的,但32位以上的CPU没有。

2、16位CPU(主要指80386和80486)内部数组总线为16位,地址总线为24位。这就意味着一个字(16bit)存不下一个地址,要用到两个字。

3、习惯把高位字称为段地址,低位字称为偏移地址。

4、程序运行时,OS会给程序分配几个内存段供程序使用,主要的有代码段(CS)、数据段(DS)、堆栈段(SS)。根据不同的编译模式这几个段可能重合。

5、当指针指向的地址与数据段的段地址相同(即处于数据段内),这时可以不记录段地址而仅记录偏移地址(只需16bit)。这种指针称为近指针(near指针)。

6、当指针指向的地址与数据段的段地址不同(即处于数据段外),这里不仅要记录偏移地址还要记录段地址(共需32bit)。这种指针称为远指针(far指针)。

7、sizeof(int near*)和sizeof(int far*)的返回值分别是2和4。

二、FAR的C语言

在DOS下(实模式)地址是分段的,每一段的长度为64K字节,刚好是16位(二进制的十六位)。

near指针的长度是16位的,所以可指向的地址范围是64K字节,通常说near指针的寻址范围是64K。

far指针的长度是32位,含有一个16位的基地址和16位的偏移量,将基地址乘以16后再与偏移量相加,(所以实际上far指针是20位的长度。)即可得到far指针的1M字节的偏移量。所以far指针的寻址范围是1M字节,超过了一个段64K的容量。例如一个far指针的段地址为0x7000,偏移量为0x1224,则该指针指向地址0x71224.如果一个far指针的段地址是0x7122,偏移量为0x0004,则该指针也指向地址0x71224。

如果没有指定一个指针是near或far,那么默认是near。所以far指针要显式指定。far指针工作起来要慢一些,因为每次访问一个far指针时,都要将数据段或程序段的数据交换出来。另外,far指针的运算也比较反常,例如上面讲到的far指针指向同一个地址,但是比较的结果却不相同。

当使用小代码或小数据存储模式时,不能编译一个有很多代码或数据的程序。因为在64K的一个段中,不能放下所有的代码与数据。为了解决这个问题,需要指定以far函数或far指针来使用这部分的空间(64K以外的空间)。许多库函数就是显式地指定为far函数的形式。far指针通常和farmalloc()这样的内存分配函数一起使用

三、FARC语言

1、在DOS的实模式下,内存地址是按段划分的,每段大小为64K字节,对应16位二进制。

2、近指针,即near指针,长度为16位,寻址范围限制在64K字节内。然而,far指针的长度更为扩展,为32位,它由16位的基地址和16位的偏移量组成,经过计算后可指向1M字节的地址,远超出了一个段的容量。例如,如果far指针的段地址为0x7000,偏移量为0x1224,实际指向地址为0x71224。同样,偏移量0x0004和段地址0x7122将指向同一地址0x71224,但这种特性可能会导致比较操作的异常。

3、far指针的使用通常在遇到特定场景时,即当程序需要处理超出单个64K段内存容量的代码或数据时。在小代码或小数据存储模式下,如果一个程序包含大量内容,不能全部放入一个段内,这时就需要使用far函数或far指针来扩展寻址范围,比如调用显式指定为far形式的库函数。此外,far指针经常与farmalloc()之类的内存分配函数配合使用,以充分利用更大的内存空间。

4、总体来说,far指针的使用是为了应对内存限制,提高程序的灵活性,但同时也会带来一定的性能开销,因为它需要额外的数据交换和运算处理。