• <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>

            我的CPP之路

            路漫漫其修遠兮
            隨筆 - 42, 文章 - 0, 評論 - 16, 引用 - 0
            數據加載中……

            指針小記_1

            沒玩過void *,玩一下試試。

            #include <cstdlib>
            #include 
            <iostream>

            using namespace std;

            typedef 
            struct test{
                
            int dataA;
                
            char *dataB;        
            }
            test;

            void *pointer;

            int main(int argc, char *argv[])
            {
                test mytest, 
            *pmytest, **ppmytest;
                pmytest 
            = &mytest;
                
            //ppmytest = &(&mytest); // non-lvalue in unary `&' 
                ppmytest = &pmytest;
                pointer 
            = ppmytest;
                mytest.dataA 
            = 1;
                cout
            <<"pmytest:\t\t"<<pmytest<<'\n';
                cout
            <<"pmytest->dataA:\t\t"<<pmytest->dataA<<'\n';
                cout
            <<"(*ppmytest)->dataA:\t"<<(*ppmytest)->dataA<<'\n';
                cout
            <<"(*(test **)pointer)->dataA:\t"<<(*(test **)pointer)->dataA<<'\n';
                
            //cout<<((test *)(*pointer))->dataA<<'\n'; //`void*' is not a pointer-to-object type 
                cout<<"ppmytest:\t\t"<<ppmytest<<'\n';
                cout
            <<"pointer:\t\t"<<pointer<<'\n';
                
            //pointer++; //ISO C++ forbids incrementing a pointer of type `void*' 
                pointer = (char *)pointer + 1;
                cout
            <<"pointer:\t\t"<<pointer<<'\n';

                system(
            "PAUSE");
                
            return EXIT_SUCCESS;
            }


            果然為通用指針,到處指,直接把二級結構指針賦給void *,呵呵。
            第一行注釋:錯誤原因,&取的是變量的地址,(&mytest)不是變量,只是一個地址值。
            第二行注釋:錯誤原因,這種轉換似乎不行,上面一行代碼先轉換成2級指針,再取值得一級指針,這行。
            第三行注釋:錯誤原因,void *不能“直接”進行算術運算。標準之所以這樣認定,是因為它堅持:進行算法操作的指針必須是確定知道其指向數據類型大小的。所以,下一行先轉換為char *,就可以了。

            以上代碼在gcc 3.4.5 中編譯通過,結果如下:

            pmytest:                0x23ff70
            pmytest->dataA:            1
            (*ppmytest)->dataA:      1
            (*(test **)pointer)->dataA:     1
            ppmytest:               0x23ff6c
            pointer:                0x23ff6c
            pointer:                0x23ff6d

            posted on 2008-03-08 11:20 yanvenhom 閱讀(698) 評論(2)  編輯 收藏 引用 所屬分類: C/C++

            評論

            # re: 指針小記_1  回復  更多評論   

            第一次發現void * 還有這種功能
            2008-03-08 22:14 | passerby

            # re: 指針小記_1  回復  更多評論   

            @passerby
            其他指針之間轉換大多都會產生編譯錯誤,void *隨便來的。
            2008-03-09 16:44 | yanvenhom
            香蕉久久夜色精品升级完成| 久久精品亚洲日本波多野结衣| 久久精品国产亚洲av水果派| 久久久亚洲欧洲日产国码是AV| 亚洲精品无码专区久久同性男| 精品久久久久中文字| 国产叼嘿久久精品久久| 精品久久久久久久久久中文字幕| 99久久精品费精品国产| 国产亚洲精久久久久久无码AV| 国产午夜精品理论片久久 | 精品人妻久久久久久888| 久久WWW免费人成一看片| 久久久无码精品亚洲日韩按摩 | 欧美日韩中文字幕久久久不卡| 久久人搡人人玩人妻精品首页| 久久香蕉国产线看观看猫咪?v| 国产精品久久久久久久app| 久久精品aⅴ无码中文字字幕不卡| 香蕉久久夜色精品升级完成| 久久发布国产伦子伦精品| 99久久国产主播综合精品| 三级片免费观看久久| 亚洲AV日韩精品久久久久久| 久久91精品国产91久久小草| 久久人妻少妇嫩草AV蜜桃| 狠狠综合久久AV一区二区三区| 99久久国产综合精品麻豆| 久久青青国产| 91视频国产91久久久| 久久久久99精品成人片| 久久午夜羞羞影院免费观看| 国产精品九九久久免费视频| 欧美亚洲色综久久精品国产| 国产福利电影一区二区三区久久久久成人精品综合 | 99久久精品九九亚洲精品| 无码国内精品久久综合88| 99久久综合狠狠综合久久| 久久精品国产男包| 久久精品国产WWW456C0M| 国产精品美女久久久m|