• <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è)
            国产精品禁18久久久夂久| 久久亚洲欧美日本精品| 欧美成a人片免费看久久| 久久只这里是精品66| 亚洲午夜久久久影院伊人| 国产精品久久毛片完整版| 久久精品不卡| 国内精品久久久久久99| 激情五月综合综合久久69| 久久久久久免费视频| 婷婷久久综合九色综合98| 久久毛片免费看一区二区三区| 1000部精品久久久久久久久| 久久九九精品99国产精品| 91精品免费久久久久久久久| 97精品伊人久久久大香线蕉| 国内精品久久九九国产精品| 精品久久久久久无码不卡| 天天综合久久久网| 久久午夜无码鲁丝片| 香蕉久久一区二区不卡无毒影院| 久久人人爽人人爽人人片AV不| 亚洲国产精品无码久久一区二区| 国产产无码乱码精品久久鸭| 成人综合伊人五月婷久久| 无码国内精品久久综合88| 一本久久久久久久| 国产精品99久久久久久人| 中文字幕无码免费久久| 久久国产AVJUST麻豆| 色婷婷久久久SWAG精品| 国产精品久久久久久久午夜片| 国产精品久久久久久一区二区三区| 久久久久噜噜噜亚洲熟女综合| 久久Av无码精品人妻系列| 久久伊人五月丁香狠狠色| 久久久久无码中| 久久久久久狠狠丁香| 日本久久久久久中文字幕| 日韩亚洲欧美久久久www综合网| 久久精品国产亚洲77777|