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

            小明思考

            高性能服務(wù)器端計(jì)算
            posts - 70, comments - 428, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            奇怪的g++的行為

            Posted on 2008-08-13 16:56 小明 閱讀(3633) 評(píng)論(18)  編輯 收藏 引用 所屬分類(lèi): C/C++
            下面的C++代碼能編譯么?

            #include <stdio.h>
            #define NUM  getnum()

            int getnum()
            {
                
            int x = 0;
                scanf(
            "%d"&x);
                printf(
            "%d\n", x);
                
            return x;
            }

            int main()
            {
                    
            int array[NUM];
                    printf(
            "array size =%d\n",sizeof(array));
                    
            return 0;
            }

            在g++中居然可以編譯。
            輸入10,返回array size=40
            輸入20,返回array size=80
            輸入-1,返回array size =-4!!

            問(wèn)題:
            1.這樣的做法符合C++標(biāo)準(zhǔn)么?連sizeof成了運(yùn)行期計(jì)算
            2.這個(gè)array的空間應(yīng)該分配在heap上,而不是stack上。g++做了什么手腳?


            答案是:
            1. C99的標(biāo)準(zhǔn):
            變長(zhǎng)數(shù)組,不過(guò)支持大小為負(fù)數(shù)的數(shù)組就有些奇怪了
            Variable-length automatic arrays are allowed in ISO C99, and as an extension GCC accepts them in C89 mode and in c++. (However, GCC's implementation of variable-length arrays does not yet conform in detail to the ISO C99 standard.) These arrays are declared like any other automatic arrays, but with a length that is not a constant expression. The storage is allocated at the point of declaration and deallocated when the brace-level is exited.

            2. 其實(shí)是分配在stack上面,動(dòng)態(tài)的調(diào)整esp就可以了

            Feedback

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 17:51 by cexer
            確實(shí)有點(diǎn)古怪,那個(gè) getnum() 明明是返回運(yùn)行期數(shù)值。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 17:51 by shaker(太子)
            真實(shí)奇思妙想啊~佩服佩服

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 17:59 by zzemu
            array的空間應(yīng)該分配在stack上。c99標(biāo)準(zhǔn)

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 18:10 by 阿福
            g++ -o main.S -S main.cpp
            這樣可以生成匯編代碼

            匯編我不太懂,通過(guò)其中調(diào)用的call __alloca大約猜到:數(shù)組被定義到堆上去了。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 18:12 by 空明流轉(zhuǎn)
            gcc的匯編表明,那個(gè)stack是一個(gè)有著作用域的堆上變量,至于sizeof,是直接在編譯期生成了一個(gè)placehold后再運(yùn)行期返回的。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 19:02 by re
            你這是把C程序當(dāng)C++編譯,自然會(huì)有問(wèn)題的.

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 19:10 by 沈臻豪(foxtail)
            暈死

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 19:35 by 過(guò)客
            傳給main的參數(shù)都錯(cuò)了~~~~

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 19:43 by DraculaW
            Variable-length automatic arrays are allowed in ISO C99, and as an extension GCC accepts them in C89 mode and in C++. (However, GCC's implementation of variable-length arrays does not yet conform in detail to the ISO C99 standard.) These arrays are declared like any other automatic arrays, but with a length that is not a constant expression. The storage is allocated at the point of declaration and deallocated when the brace-level is exited.

            http://gcc.gnu.org/onlinedocs/gcc/Variable-Length.html

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 22:35 by 陳梓瀚(vczh)
            問(wèn)題是為什么int Array[getnum()]居然可以編譯過(guò)去。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 22:35 by 陳梓瀚(vczh)
            原來(lái)是新特性啊。這是好事。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 23:25 by ZelluX
            c99的特性而已

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-13 23:52 by 踏雪赤兔
            不是很正常嗎?棧上的數(shù)組都是在運(yùn)行時(shí)“分配”的,反正就加一個(gè)偏移嘛,看不出有什么不妥

            # re: 奇怪的g++的行為[未登錄](méi)  回復(fù)  更多評(píng)論   

            2008-08-14 00:06 by jarod
            int num;
            scanf("%d", &num);
            int aaa[num];

            也可以啊?哪用寫(xiě)個(gè)宏和函數(shù)。。。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-14 09:49 by bugs_killer
            fuck 都亂套了..

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-21 13:19 by Icat
            應(yīng)該是
            %ud 而不是%d

            sizeof 返回的是 unsigned int,你當(dāng)作int在處理,
            一個(gè)極大的數(shù)就變成負(fù)數(shù)了

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-08-27 11:10 by abettor
            @Icat
            同意。
            我覺(jué)得也是因?yàn)樽冮L(zhǎng)數(shù)組把-1轉(zhuǎn)成無(wú)符號(hào)型了,但問(wèn)題是,變長(zhǎng)數(shù)組支持的長(zhǎng)度有多大?如果沒(méi)記錯(cuò),原來(lái)數(shù)組大小貌似不能超過(guò)65535。

            # re: 奇怪的g++的行為  回復(fù)  更多評(píng)論   

            2008-09-30 12:20 by 某人
            65535 那是16位的系統(tǒng),32為系統(tǒng)是4294967295個(gè)
            国产免费久久精品丫丫| 久久人妻少妇嫩草AV蜜桃| 久久久精品免费国产四虎| 国产高潮国产高潮久久久91 | 狠狠综合久久综合88亚洲| 精品无码久久久久久尤物| 精品无码人妻久久久久久| 久久精品毛片免费观看| 久久99精品久久久久久不卡| 亚洲va国产va天堂va久久| 国产精品久久久99| 久久男人Av资源网站无码软件| 久久99精品久久久久久噜噜| 久久午夜无码鲁丝片| 久久久久久久久66精品片| 久久精品成人免费网站| 一本久久a久久精品亚洲| 久久久WWW免费人成精品| 国产∨亚洲V天堂无码久久久| 婷婷久久综合九色综合九七| 久久久久免费精品国产| 国产成人久久精品一区二区三区| 久久久久女教师免费一区| 久久精品国产影库免费看| 欧美va久久久噜噜噜久久| 国产精品久久新婚兰兰| 色99久久久久高潮综合影院| 国产高清美女一级a毛片久久w | 久久99精品免费一区二区| 久久91综合国产91久久精品| 伊人久久大香线蕉亚洲五月天| 久久综合视频网| 7777久久久国产精品消防器材| 中文字幕久久亚洲一区| 无夜精品久久久久久| 久久免费99精品国产自在现线| 久久WWW免费人成—看片| 久久国产视屏| 亚洲成av人片不卡无码久久| 欧美亚洲日本久久精品| 欧美午夜精品久久久久久浪潮|