• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            C/C++中的近指令、遠(yuǎn)指針和巨指針

             今天Ben忽然問我。。。LPVOID中的L是什么意思,一下把我問住了。不可能是長的意思是。查了下。。竟然是遠(yuǎn)指針的含義,都沒學(xué)過這個東東。學(xué)習(xí)了下。。以前都沒聽說指針還有遠(yuǎn)、近、巨之分的,從沒聽說過什么近指針、遠(yuǎn)指針和巨指針。

            char near *p; /*定義一個字符型“近”指針*/
            char far *p; /*定義一個字符型“遠(yuǎn)”指針*/
            char huge *p; /*定義一個字符型“巨”指針*/

            首先要從8086處理器體系結(jié)構(gòu)和匯編淵源學(xué)起。8086是一個16位處理器,它設(shè)定了四個段寄存器,專門用來保存段地址:CS(Code Segment):代碼段寄存器;DS(Data Segment):數(shù)據(jù)段寄存器;SS(Stack Segment):堆棧段寄存器;ES(Extra Segment):附加段寄存器。8086采用段式訪問,訪問本段(64K范圍內(nèi))的數(shù)據(jù)或指令時,不需要變更段地址(意味著段地址寄存器不需修改),而訪問本段范圍以外的數(shù)據(jù)或指令時,則需要變更段地址(意味著段地址寄存器需要修改)。
            因此,在16位處理器環(huán)境下,如果訪問本段內(nèi)地址的值,用一個16位的指針(表示段內(nèi)偏移)就可以訪問到;而要訪問本段以外地址的值,則需要用16位的段內(nèi)偏移+16位的段地址,總共32位的指針。

            這樣,就可以知道遠(yuǎn)、近指針的區(qū)別:

            近指針是只能訪問本段、只包含本段偏移的、位寬為16位的指針;
            遠(yuǎn)指針是能訪問非本段、包含段偏移和段地址的、位寬為32位的指針。

            近指針只能對64k字節(jié)數(shù)據(jù)段內(nèi)的地址進(jìn)行存取,如:

            char near *p;
            p=(char near *)0xffff;

            遠(yuǎn)指針是32位指針,它表示段地址:偏移地址,遠(yuǎn)指針可以進(jìn)行跨段尋址,可以訪問整個內(nèi)存的地址。如定義遠(yuǎn)程指針p指向0x1000段的0x2號地址,即1000:0002,則可寫作:
            char far *p;
            p=(char far *)0x10000002;

            除了遠(yuǎn)指針和近指針外,還有一個巨指針的概念。
            和遠(yuǎn)指針一樣,巨指針也是32位的指針,指針也表示為16位段:16位偏移,也可以尋址任何地址。它和遠(yuǎn)指針的區(qū)別在于進(jìn)行了規(guī)格化處理。遠(yuǎn)指針沒有規(guī)格化,可能存在兩個遠(yuǎn)指針實(shí)際指向同一個物理地址,但是它們的段地址和偏移地址不一樣,如23B0:0004和23A1:00F4都指向同一個物理地址23604!巨指針通過特定的例程保證:每次操作完成后其偏移量均小于10h,即只有最低4位有數(shù)值,其余數(shù)值都被進(jìn)位到段地址上去了,這樣就可以避免Far指針在64K邊界時出乎意料的回繞的行為。當(dāng)然,一次操作必須小于64K。下面的函數(shù)可以將遠(yuǎn)指針轉(zhuǎn)換為巨指針:
            void normalize(void far ** p)
            {
              *p=(void far *)(((long)*p&0xffff000f)+(((long)*p&0x0000fff00<<12));
            }

            從上面的函數(shù)中 可以看到指針之指針的使用,這個函數(shù)要修改指針的值,因此必須傳給它的指針的指針作為參數(shù)。

            看到最后。。。。學(xué)習(xí)到了一點(diǎn)。。讓人很郁悶的事實(shí)。。。

            近指針、遠(yuǎn)指針、巨指針是段尋址的16bit處理器的產(chǎn)物(如果處理器是16位的,但是不采用段尋址的話,也不存在近指針、遠(yuǎn)指針、巨指針的概念),當(dāng)前普通PC所使用的32bit處理器(80386以上)一般運(yùn)行在保護(hù)模式下的,指針都是32位的,可平滑地址,已經(jīng)不分遠(yuǎn)、近指針了。但是在嵌入式系統(tǒng)領(lǐng)域下,8086的處理器仍然有比較廣泛的市場,如AMD公司的AM186ED、AM186ER等處理器,開發(fā)這些系統(tǒng)的程序時,我們還是有必要弄清楚指針的尋址范圍。

            一個多小的學(xué)習(xí)。。。。。。。白學(xué)了。。。。。。-_______________________________-

            posted on 2007-10-16 15:00 Randy 閱讀(883) 評論(1)  編輯 收藏 引用

            評論

            # re: C/C++中的近指令、遠(yuǎn)指針和巨指針 2009-03-01 14:41 lion3875

            寫的非常詳細(xì),而且有自己的理解,很不錯的文章,建議對巨指針的解釋再詳細(xì)一些,有點(diǎn)沒看明白  回復(fù)  更多評論   

            <2007年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿(3)

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            午夜人妻久久久久久久久| 无码国内精品久久人妻蜜桃| 亚洲愉拍99热成人精品热久久| 久久激情亚洲精品无码?V| 国产2021久久精品| 欧美激情精品久久久久| 久久精品国产91久久麻豆自制| 国产情侣久久久久aⅴ免费| 久久精品黄AA片一区二区三区| 亚洲精品乱码久久久久久自慰 | 亚洲午夜久久久精品影院| 99久久无色码中文字幕| 亚洲国产精品久久66| 九九热久久免费视频| 久久综合视频网站| 久久久久久久91精品免费观看| 久久99国产精品久久99小说| 伊人久久无码精品中文字幕| 亚洲狠狠婷婷综合久久蜜芽| 国产午夜福利精品久久2021 | 欧美亚洲国产精品久久久久| 亚洲国产成人久久笫一页| 亚洲精品无码久久久久| 久久91精品久久91综合| 久久精品成人免费国产片小草| 一本一道久久a久久精品综合| 精品人妻伦九区久久AAA片69| 久久人人爽人人爽人人片AV不| WWW婷婷AV久久久影片| 一级做a爰片久久毛片人呢| 久久免费视频一区| 久久久久久无码Av成人影院| 99久久精品久久久久久清纯| 久久婷婷色综合一区二区| 97r久久精品国产99国产精| 久久久久女教师免费一区| 亚洲精品乱码久久久久久蜜桃不卡| 69SEX久久精品国产麻豆| 亚洲国产日韩综合久久精品| 2021精品国产综合久久| 久久天天躁夜夜躁狠狠躁2022|