• <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
            精品乱码久久久久久夜夜嗨| 亚洲国产精品无码久久久秋霞2| 久久国产成人精品麻豆| 97久久精品人人澡人人爽| 久久99国产精品99久久| 精品久久久久久无码专区| 热久久这里只有精品| 亚洲欧美一级久久精品| 久久er99热精品一区二区| 国产一区二区精品久久凹凸| 欧美亚洲国产精品久久| 久久99国产亚洲高清观看首页 | 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 香蕉aa三级久久毛片| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 国产99久久九九精品无码| 偷偷做久久久久网站| 91精品国产91久久久久久蜜臀| 中文字幕无码久久久| 国内精品久久久久| 午夜精品久久久久久99热| 久久精品国产一区二区电影| 国产精品久久久久影院嫩草 | 精品综合久久久久久888蜜芽| 国产精品欧美久久久久无广告| 亚洲综合精品香蕉久久网| 久久久久亚洲?V成人无码| 伊人久久大香线焦综合四虎| 欧美午夜精品久久久久免费视| 一个色综合久久| 欧美一区二区久久精品| 久久精品国产第一区二区| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲狠狠婷婷综合久久蜜芽| 久久人人超碰精品CAOPOREN| a级毛片无码兔费真人久久| 久久国产成人精品麻豆| 久久美女人爽女人爽| 2020最新久久久视精品爱 | 久久99精品久久久久久水蜜桃| 婷婷综合久久狠狠色99h|