C/C++中near、far和huge的区别及使用

文章来自http://hi.baidu.com/fwxh101/blog/item/15f7b382720b31c39123d9b7.html

 

1. near、far和huge的由来

    在80286以前的微处理器(CPU)组成的确16位机上,Windows操作系统(包括DOS)对于内存是分段使用的(分段内存模 式,Segment   Memory   Mode)。运行在这些16位CPU微机上的Windows(Windows   1.0-3.1)被称为“Win16”。从80386开始的32位CPU开始,为了兼容,也采用上述分段内存模式,这就导致了near(short)、 far(long)指针的出现。  

    从Windows 95开始的32位机上,Windows支持32位平面内存模式(与“分段内存模式”区别),相应地,Windows 95以后的Windows也就是我们常说的“Win32”。为Win32写的程序使用32位的线性地址空间。   

    由此可见,如果你想写在Win16上也能运行的程序,才会涉及到newr、far指针的概念。在Win32上,指针无near、far的区分。

2. 存贮属性

    C指针有三种存贮属性,分别是:    

    near   (近)指针:16位段内偏移地址    

    far(远)指针:16位段地址+16位段内偏移地址    

    huge(巨)指针:32位规格化的具有唯一性的内存地址  

    C语言的存贮属性由六种编译模式决定(参见TC集成环境菜单中的option->compiler->model选项),默认的编译模式为 small,   在该编译模式下,指针的默认属性为near。 

3. near、far和huge的使用

    关键字near和far受目标计算机体系结构的影响。目前编程中使用不多。

      near关键字创建一个指向可寻址内存低端部分的目标指针。这些指针占用内存的单一字节,并且他们能够指向的内存单元被限制到256个位置,通常是在0x0000~0x00ff范围中。

      int near * ptr;

    far关键字创建一个能够指向内存中任何数据的指针。

    far 是C/C++语言在16位系统中用以标明指针是个远指针的修饰符,在32位系统已经废除不用了。

    远指针是说指针所指向的地址已经超出了64K,所以需要使用DS加偏移量的方法来寻址,而不能直接寻址。其反义的修饰符是near。

    举例:

          int far *fptr;    
          fptr=(int far*)0xb0000000;

     PC机的存储器地址是由段地址和偏移地址组合而成,每一段不能超过64k字节地址,因而统一个段内的地址存取,用偏移地址就可以实现,因段地址寄存器所存 的段地址是不变。当用指针时,只16位就够了,这一类就是near指针。当要在另一个段内取数据,就要跨越段,既要指明存取段的段地址和偏移地址,这时段 地址寄存器所存段地址要改变,在使用指针指向另一个段内地址时,就要用32位表示,就是far指针了。

4. 补充

    near指针是16位指针,依赖一个段地址寄存器,指针变量就是位移量,利用 段地址寄存器+指针 来寻址,所以有64K之限制。

    far 指针是32位指针,不但有16位的位移量,还有16位的段地址,但此指针有个缺陷,增量时只加到位移部分,一旦16位的位移量超过了FFFF就会回到这个段地址的初始。

    所以,又引入了huge指针,huge指针与far一样,其区别仅在于使用了标准化的方法来表示,这样所有的地址都有一个唯一的表示方法,从而避免了far指针的问题。

    空指针规定了一种指针状态,如果没有这个空指针,就如数字没有了0。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值