青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

小明思考

高性能服務器端計算
posts - 70, comments - 428, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

奇怪的g++的行為

Posted on 2008-08-13 16:56 小明 閱讀(3664) 評論(18)  編輯 收藏 引用 所屬分類: 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!!

問題:
1.這樣的做法符合C++標準么?連sizeof成了運行期計算
2.這個array的空間應該分配在heap上,而不是stack上。g++做了什么手腳?


答案是:
1. C99的標準:
變長數組,不過支持大小為負數的數組就有些奇怪了
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. 其實是分配在stack上面,動態的調整esp就可以了

Feedback

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-13 17:51 by cexer
確實有點古怪,那個 getnum() 明明是返回運行期數值。

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-13 17:59 by zzemu
array的空間應該分配在stack上。c99標準

# re: 奇怪的g++的行為  回復  更多評論   

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

匯編我不太懂,通過其中調用的call __alloca大約猜到:數組被定義到堆上去了。

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-13 19:02 by re
你這是把C程序當C++編譯,自然會有問題的.

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-13 19:35 by 過客
傳給main的參數都錯了~~~~

# re: 奇怪的g++的行為  回復  更多評論   

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++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為[未登錄]  回復  更多評論   

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

也可以啊?哪用寫個宏和函數。。。

# re: 奇怪的g++的行為  回復  更多評論   

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

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-21 13:19 by Icat
應該是
%ud 而不是%d

sizeof 返回的是 unsigned int,你當作int在處理,
一個極大的數就變成負數了

# re: 奇怪的g++的行為  回復  更多評論   

2008-08-27 11:10 by abettor
@Icat
同意。
我覺得也是因為變長數組把-1轉成無符號型了,但問題是,變長數組支持的長度有多大?如果沒記錯,原來數組大小貌似不能超過65535。

# re: 奇怪的g++的行為  回復  更多評論   

2008-09-30 12:20 by 某人
65535 那是16位的系統,32為系統是4294967295個
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩在线亚洲一区蜜芽| 欧美色视频日本高清在线观看| 国产网站欧美日韩免费精品在线观看 | 欧美激情一区二区三级高清视频 | 亚洲天堂网在线观看| 欧美色偷偷大香| 亚洲欧美成人网| 午夜精品视频在线| 经典三级久久| 亚洲人成在线观看一区二区| 欧美日韩精品免费看 | 国产一区二区三区日韩欧美| 裸体一区二区三区| 欧美精品久久一区二区| 亚洲一区二区日本| 久久se精品一区精品二区| 1000部国产精品成人观看| 亚洲区一区二| 国产欧美一区二区精品婷婷| 免费观看久久久4p| 欧美日韩久久不卡| 久久久激情视频| 麻豆freexxxx性91精品| 亚洲天堂成人在线观看| 欧美一区二区啪啪| 亚洲精品一区二区三区樱花| 一区二区三区视频在线观看| 国产一区二区三区精品久久久 | 亚洲——在线| 久久综合色一综合色88| 在线性视频日韩欧美| 久久狠狠久久综合桃花| 中国av一区| 久久中文字幕一区| 亚洲欧洲99久久| 欧美成人高清| 久久免费视频网| 欧美三级电影一区| 女女同性精品视频| 国产日韩精品在线| 亚洲系列中文字幕| 亚洲精品中文字| 久久久综合精品| 欧美一区二区久久久| 欧美女同视频| 亚洲福利视频网| 永久域名在线精品| 亚洲欧美日韩在线一区| 亚洲在线黄色| 欧美另类女人| 亚洲国产二区| 亚洲精品国产无天堂网2021| 久久精品日产第一区二区| 亚洲制服av| 欧美视频四区| 一区二区三区高清视频在线观看| 亚洲欧洲在线播放| 美女诱惑黄网站一区| 免费久久99精品国产| 国产一区二区在线观看免费| 亚洲一区在线观看免费观看电影高清 | 久久精品夜色噜噜亚洲a∨| 亚洲一区欧美二区| 欧美日韩国产综合一区二区| 亚洲第一网站| 亚洲精品乱码久久久久久日本蜜臀| 久久免费精品视频| 蜜月aⅴ免费一区二区三区| 国产日本欧美一区二区| 欧美一区二区成人6969| 欧美一区二区黄色| 国产日韩精品在线| 久久精品99国产精品日本| 久久久久久久网站| 精品88久久久久88久久久| 久久久99免费视频| 欧美国产欧美亚州国产日韩mv天天看完整| 黄色国产精品一区二区三区| 久久久久久久综合色一本| 久久综合五月| 99成人在线| 欧美午夜精品一区| 亚欧成人精品| 欧美大片免费观看| 久久精品欧洲| 欧美成人在线网站| 亚洲乱码国产乱码精品精可以看 | 女人香蕉久久**毛片精品| 亚洲一二三区在线| 国产精品入口尤物| 久久国内精品自在自线400部| 免费观看日韩av| av成人手机在线| 国产精品福利片| 久久国产99| 亚洲乱亚洲高清| 午夜精品久久久久久久99水蜜桃 | 亚洲综合色在线| 国内精品久久久久久久97牛牛| 久久久久久一区二区| 亚洲国产精品嫩草影院| 西西人体一区二区| 亚洲国产99精品国自产| 欧美日韩在线直播| 久久精品国产亚洲一区二区| 亚洲毛片av| 麻豆亚洲精品| 欧美一区2区视频在线观看| 91久久久亚洲精品| 国产精品一香蕉国产线看观看| 美日韩丰满少妇在线观看| 亚洲一区视频在线| 亚洲人成啪啪网站| 裸体一区二区三区| 欧美在线视频网站| 99精品视频免费在线观看| 精品av久久707| 国产精品久久久久久久第一福利| 麻豆免费精品视频| 性欧美大战久久久久久久久| 亚洲精品美女在线观看| 欧美成人午夜剧场免费观看| 欧美一区国产一区| 亚洲视频在线观看免费| 亚洲国产精品第一区二区| 国产精品网红福利| 国产精品vip| 欧美日本在线播放| 欧美风情在线观看| 久久综合久久综合这里只有精品| 欧美一级免费视频| 亚洲影院色无极综合| 亚洲免费观看在线观看| 亚洲黄色天堂| 一区二区福利| 99精品免费| 99国产精品视频免费观看一公开 | 国模大胆一区二区三区| 国产精品欧美风情| 国产精品嫩草影院av蜜臀| 欧美视频网站| 欧美涩涩视频| 国产精品porn| 国产精品美女久久福利网站| 欧美亚日韩国产aⅴ精品中极品| 欧美精选一区| 欧美日韩一区二区精品| 欧美午夜精品久久久久免费视 | 国产精品xvideos88| 欧美日本亚洲| 欧美三区美女| 国产毛片一区| 国产一区香蕉久久| 伊人久久大香线蕉av超碰演员| 国产一区二区日韩精品| 亚洲大片精品永久免费| 亚洲国产精品一区二区www| 亚洲国产精品免费| 日韩视频不卡中文| 一区二区欧美在线| 香蕉久久精品日日躁夜夜躁| 久久精品国产综合| 亚洲福利电影| 亚洲久久成人| 性娇小13――14欧美| 玖玖综合伊人| 欧美午夜精品理论片a级大开眼界| 国产精品久久久久9999高清| 国产色爱av资源综合区| 亚洲第一精品影视| 亚洲天堂av在线免费| 久久成人人人人精品欧| 亚洲第一在线综合网站| 一区二区三区欧美| 久久久久.com| 欧美日韩一区视频| 国产在线精品成人一区二区三区| 亚洲国产精品悠悠久久琪琪| 一区二区免费看| 久久久91精品国产| 亚洲国产高清自拍| 欧美一二三区在线观看| 欧美激情a∨在线视频播放| 国产欧美精品一区二区色综合| 亚洲动漫精品| 香蕉久久夜色精品| 亚洲韩国青草视频| 亚洲欧美中文另类| 欧美日韩爆操| 亚洲高清一区二| 欧美一区二区精品久久911| 亚洲国产精彩中文乱码av在线播放| 在线亚洲一区二区| 欧美国产日韩在线| 极品尤物久久久av免费看| 亚洲综合不卡| 亚洲精品你懂的| 香蕉成人啪国产精品视频综合网| 欧美久久久久免费| 在线观看亚洲一区|