C/C++语言里的near和far是什么意思?
2019獨角獸企業重金招聘Python工程師標準>>>
C語言里的near和far是什么意思?-CSDN論壇-CSDN.NET-中國最大的IT技術社區
http://bbs.csdn.net/topics/390275885
32位系統中已經沒有用了,16位才有用。
近指針、遠指針,這是16位CPU造就的怪胎。32位以上的CPU沒這玩意。
16位CPU(主要指80386和80486)內部數據總線為16位,地址總線為24位。這就意味著一個字(16bit)存不下一個地址,要用到兩個字。習慣把高位字稱為段地址,低位字稱為偏移地址。
程序運行時,OS會給程序分配幾個內存段供程序使用,主要的有代碼段(CS)、數據段(DS)、堆棧段(SS)。根據不同的編譯模式這幾個段可能重合。
far 遠跳轉/指針,它會帶一個段前綴。near 沒有段前綴。
當指針指向的地址與數據段的段地址相同(即處于數據段內),這時可以不記錄段地址而僅記錄偏移地址(只需16bit)。這種指針稱為近指針(near指針)。在16位CPU下,缺省的指針類型。
當指針指向的地址與數據段的段地址不同(即處于數據段外),這里不僅要記錄偏移地址還要記錄段地址(共需32bit)。這種指針稱為遠指針(far指針)。
===================
在visual studio中的minwindef.h文件中對far和near的定義如下:
#undef far
#undef near
#define far
#define near
這充分說明在32位系統下,far、near已經無效了。
================
C語言近程型(near)和遠程型(far)的區別是什么?_C語言中文網
http://c.biancheng.net/cpp/html/1685.html
因為DOS使用的是段地址結構尋址機制,所以近程型和遠程型數據的概念是運行DOS的PC機所獨有的。其它操作系統,例如UNIX和Wndows NT,使用的是平面地址機制,沒有近程型或遠程型限制。
感覺far和near應該是只與CPU位數有關的東西,在目前32位、64位CPU大行其道的情況下,它們已經成了歷史。
轉載于:https://my.oschina.net/ray1421/blog/703298
總結
以上是生活随笔為你收集整理的C/C++语言里的near和far是什么意思?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: iOS - OC SQLite 数据库
- 下一篇: Mac上关于shell使用Python3