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

gifty

2011年5月7日

全局/靜態變量內存布局

測試程序:

#include

#include

using namespace std;

static int gs_num[53];

char g_buf1[190];

char g_buf2[232];

char g_buf3[] = "That's really a test!";

static char gs_buf1[233];

class Base

{

public:

Base()

{

memset(buf, 1, 100);

}

~Base()

{

}

private:

char buf[100];

};

Base g_base;

static Base gs_base;

void func()

{

static int s1[10];

static char s2[16] = "fs";

static int s3[20] = {15};

s1[10] = 3;

int a = s1[0]+ s2[0];

}

int main()

{

static int a[10] = {3};

static int b[10] = {4};

//func();

static Base base;

static char temp[100];

static char temp1[39];

static Base base1;

int c = a[0] + b[0];

cout<gs_buf1[0] = 'a';

return 0;

}

內存布局

在main入口處設置斷點后內存布局如下:

0x8049160 : 1952540756 1914729255 1819042149 543236217

0x8049170 : 1953719668 33 0 0

0x8049180 <_ZZ4mainE1b>: 4 0 0 0

0x8049190 <_ZZ4mainE1b+16>: 0 0 0 0

0x80491a0 <_ZZ4mainE1b+32>: 0 0 0 0

0x80491b0: 0 0 0 0

0x80491c0 <_ZZ4mainE1a>: 3 0 0 0

0x80491d0 <_ZZ4mainE1a+16>: 0 0 0 0

0x80491e0 <_ZZ4mainE1a+32>: 0 0 29542 0

0x80491f0 <_ZZ4funcvE2s2+8>: 0 0 0 0

0x8049200 <_ZSt4cout@@GLIBCXX_3.4>: 3086816908 3086816928 6 0

0x8049210 <_ZSt4cout@@GLIBCXX_3.4+16>: 4098 0 0 0

0x8049220 <_ZSt4cout@@GLIBCXX_3.4+32>: 0 0 0 0

0x8049230 <_ZSt4cout@@GLIBCXX_3.4+48>: 0 0 0 0

0x8049240 <_ZSt4cout@@GLIBCXX_3.4+64>: 0 0 0 0

0x8049250 <_ZSt4cout@@GLIBCXX_3.4+80>: 0 0 0 0

0x8049260 <_ZSt4cout@@GLIBCXX_3.4+96>: 0 0 8 134517288

0x8049270 <_ZSt4cout@@GLIBCXX_3.4+112>: 3086833084 0 0 3086827968

0x8049280 <_ZSt4cout@@GLIBCXX_3.4+128>: 3086829728 3086830428 3086830420 0

0x8049290 : 0 0 0 0

0x80492a0 : 0 0 0 0

0x80492b0 : 0 0 0 0

0x80492c0 : 0 0 0 0

0x80492d0 : 0 0 0 0

0x80492e0 : 0 0 0 0

0x80492f0 : 0 0 0 0

0x8049300 : 0 0 0 0

0x8049310 : 0 0 0 0

0x8049320 : 0 0 0 0

0x8049330 : 0 0 0 0

0x8049340 : 0 0 0 0

0x8049350 : 0 0 0 0

0x8049360 : 0 0 0 0

0x8049370 : 0 0 0 0

0x8049380 : 0 0 0 0

0x8049390 : 0 0 0 0

0x80493a0 : 0 0 0 0

0x80493b0 : 0 0 0 0

0x80493c0 : 0 0 0 0

0x80493d0 : 0 0 0 0

0x80493e0 : 0 0 0 0

0x80493f0 : 0 0 0 0

0x8049400 : 0 0 0 0

0x8049410 : 0 0 0 0

0x8049420 : 0 0 0 0

0x8049430 : 0 0 0 0

0x8049440 : 0 0 0 0

0x8049450: 0 0 0 0

0x8049460 : 16843009 16843009 16843009 16843009

0x8049470 : 16843009 16843009 16843009 16843009

0x8049480 : 16843009 16843009 16843009 16843009

0x8049490 : 16843009 16843009 16843009 16843009

0x80494a0 : 16843009 16843009 16843009 16843009

0x80494b0 : 16843009 16843009 16843009 16843009

0x80494c0 : 16843009 0 0 0

0x80494d0: 0 0 0 0

0x80494e0 <_ZL7gs_base>: 16843009 16843009 16843009 16843009

0x80494f0 <_ZL7gs_base+16>: 16843009 16843009 16843009 16843009

0x8049500 <_ZL7gs_base+32>: 16843009 16843009 16843009 16843009

0x8049510 <_ZL7gs_base+48>: 16843009 16843009 16843009 16843009

0x8049520 <_ZL7gs_base+64>: 16843009 16843009 16843009 16843009

0x8049530 <_ZL7gs_base+80>: 16843009 16843009 16843009 16843009

0x8049540 <_ZL7gs_base+96>: 16843009 0 0 0

0x8049550 <_ZGVZ4mainE5base1>: 0 0 0 0

0x8049560 <_ZL7gs_buf1>: 0 0 0 0

0x8049570 <_ZL7gs_buf1+16>: 0 0 0 0

0x8049580 <_ZL7gs_buf1+32>: 0 0 0 0

0x8049590 <_ZL7gs_buf1+48>: 0 0 0 0

0x80495a0 <_ZL7gs_buf1+64>: 0 0 0 0

---Type to continue, or q to quit---

0x80495b0 <_ZL7gs_buf1+80>: 0 0 0 0

0x80495c0 <_ZL7gs_buf1+96>: 0 0 0 0

0x80495d0 <_ZL7gs_buf1+112>: 0 0 0 0

0x80495e0 <_ZL7gs_buf1+128>: 0 0 0 0

0x80495f0 <_ZL7gs_buf1+144>: 0 0 0 0

0x8049600 <_ZL7gs_buf1+160>: 0 0 0 0

0x8049610 <_ZL7gs_buf1+176>: 0 0 0 0

0x8049620 <_ZL7gs_buf1+192>: 0 0 0 0

0x8049630 <_ZL7gs_buf1+208>: 0 0 0 0

0x8049640 <_ZL7gs_buf1+224>: 0 0 0 0

0x8049650: 0 0 0 0

0x8049660 <_ZZ4mainE5base1>: 0 0 0 0

0x8049670 <_ZZ4mainE5base1+16>: 0 0 0 0

0x8049680 <_ZZ4mainE5base1+32>: 0 0 0 0

0x8049690 <_ZZ4mainE5base1+48>: 0 0 0 0

0x80496a0 <_ZZ4mainE5base1+64>: 0 0 0 0

0x80496b0 <_ZZ4mainE5base1+80>: 0 0 0 0

0x80496c0 <_ZZ4mainE5base1+96>: 0 0 0 0

0x80496d0: 0 0 0 0

0x80496e0 <_ZZ4mainE5temp1>: 0 0 0 0

0x80496f0 <_ZZ4mainE5temp1+16>: 0 0 0 0

0x8049700 <_ZZ4mainE5temp1+32>: 0 0 0 0

0x8049710: 0 0 0 0

0x8049720 <_ZZ4mainE4base>: 0 0 0 0

0x8049730 <_ZZ4mainE4base+16>: 0 0 0 0

0x8049740 <_ZZ4mainE4base+32>: 0 0 0 0

0x8049750 <_ZZ4mainE4base+48>: 0 0 0 0

0x8049760 <_ZZ4mainE4base+64>: 0 0 0 0

0x8049770 <_ZZ4mainE4base+80>: 0 0 0 0

0x8049780 <_ZZ4mainE4base+96>: 0 0 0 0

0x8049790: 0 0 0 0

0x80497a0 <_ZZ4funcvE2s1>: 0 0 0 0

0x80497b0 <_ZZ4funcvE2s1+16>: 0 0 0 0

0x80497c0 <_ZZ4funcvE2s1+32>: 0 0 0 0

0x80497d0: 0 0 0 0

0x80497e0: 0 0 0 0

0x80497f0: 0 0 0 0

0x8049800: 0 0 0 0

0x8049810: 0 0 0 0

0x8049820: 0 0 0 0

0x8049830: 0 0 0 0

0x8049840: 0 0 0 0

0x8049850: 0 0 0 0

分析結果:

全局變量與靜態變量的唯一區別在于鏈接屬性,全局變量為外部鏈接屬性,全局靜態變量(類內部的靜態變量)為內部鏈接屬性,函數內部的靜態變量無鏈接屬性。

注:對于類內部的靜態變量,類名相當于一個命名空間,而全局靜態變量的命名空間為::(全局命名空間),所以它們本質上無差別!

全局變量和靜態變量內存布局基本相同,這里一并考慮。

全局/靜態變量的內存分配主要是遵循一個大的原則,將初始化的和未初始化的變量分開存放,初始化的變量被放在全局數據區,未初始化的變量放在BSS段,這樣有一個好處,BSS段在文件中是沒有大小的,只有一個地址,所有未初始化的全局靜態變量都指向這個地址,這樣可以減小文件的大小。而在運行時,才會為BSS段分配內存空間,并且全部初始化為0,所以未初始化的全局/靜態變量載入內存后,默認值為0。

然后我們看內存布局:

前面4個變量依次是,g_buf3,_ZZ4mainE1b,_ZZ4mainE1a和_ZZ4funcvE2s2,編譯器在編譯時為了防止名稱沖突,會對變量函數名進行名稱修飾,linux下可用c++filt工具進行還原。

還原后的變量依次是:

g_buf3,main函數中的靜態變量b、a和func中的靜態變量s2。

這4個是初始化了的全局/靜態變量,所以被放在全局初始化區,這里我們得出以下幾點結論。

1、可以發現s2和s3都被初始化了,可是只有s2被分配內存空間,而s3并未分配內存空間,這是因為linux中為靜態變量分配內存是根據該變量是否被使用來判斷的,如果一個靜態變量定義后,未發現它被其它變量引用了,將不會為其分配內存空間。

2、對于全局變量,不管它是否被使用了,都會為其分配內存空間。

3、在函數中的靜態變量,在內存中的順序恰恰和它們在函數中的聲明順序相反(目前尚不知這樣做的原因)。

這里有一個疑問,g_base和gs_base這兩個變量被初始化了,為什么它們被放在未初始化的全局數據區。這是因為g_base和gs_base這兩個變量是在運行時通過調用構造函數被初始化的,在編譯時我們是無法知道它們的值的,所以在編譯時它們也被放在了BSS段。所以這里得出結論:

4、全局/靜態類變量在內存中被放在未初始化數據區。

下面我們看看未初始化數據區里面的變量,依次是

g_buf1、g_buf2、g_base、gs_base、main函數的base1、temp1、base,func函數的s1。

可以看到g_base、gs_base值不為0,而base1,base的值為0,因為我的斷點是在main函數入口處設置的,所以全局類變量的構造函數已被調用過了,而main函數內的類變量的構造函數尚未調用,但是它們的內存空間已被分配,這印證了以上結論4。

posted @ 2011-05-07 15:52 gifty 閱讀(889) | 評論 (0)編輯 收藏

2011年5月2日

GCC預編譯頭技術

最近在弄GCC的預編譯頭,用C++開發工程最難以忍受的就是烏龜似地的編譯速度,用VC開發工程的時候,VC會默認幫我們引入預編譯頭,那么GCC呢?其實GCC也是支持預編譯頭得, http://lych.yo2.cn/articles/淺談gcc預編譯頭技術.html 這篇文章就詳細講解了如何GCC下預編譯頭得一些知識, 所以具體如何在GCC中加入預編譯頭,大家可以參考這篇文章。

在給GCC添加預編譯頭時也遇到了一些問題,并且對C++/C的編譯有了一些新的認識!


很多在linux下寫程序的人都應該看過《和我一起寫Makefile》這篇文章,里面講過如何利用GCC的-MM選項自動生成依賴:


%.d: %.cpp
@$(GPP) -MM $(INCLUDE) $< > $@.tmp;\
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.tmp > $@;\
rmf $@.tmp


這里利用了一個模式規則,將CPP文件依賴的頭文件寫到一個.d文件中,執行Makefile時我們只需要include這些.d文件,GCC就會根據里面的依賴關系來生成對應的.o文件了!
但是實際上GCC的自動推導能力非常強大,我們其實只需要寫下一條這樣的模式就可以了,
%.o:%.cpp
@$(GPP) $(CPPFLAGS) $< $(INCLUDE)


GCC就會自動推導出CPP文件所需要依賴的頭文件進行編譯了!


如果你在自己的工程中加入了預編譯頭,你就必須使用下面一種模式。
舉個例子,比如你們工程開發了一些基礎庫,已經比較穩定了,除了一些少量的BUG FIX外,很少需要修改,當你通過源碼形式引用的時候,你當然不希望每次編譯的時候都去編譯
這些基礎庫,如是你決定將他們加入預編譯頭中去,但是當你使用第一種方式寫Makefile的時候,你發現被你加入到預編譯頭中的頭文件還是被重復編譯了,因為-MM選項會把你CPP文件
依賴的非系統頭文件全部放在對應的.d文件中。但是當你使用第二種Makefile時,GCC看到一個預編譯頭后,他不會按照常規的方式將它展開,而是回去尋找對應的.gch文件,然后進行編譯,
如果你想一探究竟的話,編譯加上-H選項就可以看出其中的差異了!

這樣生成的預編譯頭如果要使用的話,需要和編譯CPP文件使用相同的選項,否則后出現一些奇怪的編譯錯誤,我的做法是寫一個預編譯頭得模式:

%.h.gch:%.h
$(GPP) $(CPPFLAGS) $< $(INCLUDE)

posted @ 2011-05-02 15:50 gifty 閱讀(1980) | 評論 (0)編輯 收藏

僅列出標題  
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導航

統計

常用鏈接

留言簿

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲美女91| 日韩亚洲欧美一区| 久久久国际精品| 久久国产66| 亚洲第一黄网| 亚洲欧洲免费视频| 欧美日本簧片| 欧美一级电影久久| 久久久久久穴| 一区二区三区黄色| 亚洲已满18点击进入久久| 国产日韩一区二区| 欧美激情一区二区三级高清视频 | 久久久综合网站| 久久久久久久久综合| 亚洲国产日韩在线| 中文在线资源观看网站视频免费不卡 | 性欧美长视频| 最新国产精品拍自在线播放| 亚洲精品字幕| 国产真实乱偷精品视频免| 欧美v日韩v国产v| 欧美日韩亚洲一区二区三区在线 | 日韩西西人体444www| 夜夜爽夜夜爽精品视频| 国产日韩欧美成人| 亚洲激情社区| 国内精品伊人久久久久av一坑| 亚洲欧洲日产国产综合网| 国产精品乱看| 欧美国产另类| 国产亚洲aⅴaaaaaa毛片| 亚洲黄一区二区| 国产一区二区中文| 在线亚洲一区| 日韩网站在线观看| 欧美一区二区大片| 亚洲综合成人在线| 欧美国产综合视频| 麻豆精品国产91久久久久久| 国产精品久久久久久久7电影| 美女精品在线观看| 国产日韩免费| 亚洲一区二区视频在线观看| 亚洲美女区一区| 久久精品在线免费观看| 午夜精品久久久久| 欧美视频免费| 亚洲电影在线播放| 亚洲第一黄色| 久久久精品国产免费观看同学| 先锋a资源在线看亚洲| 欧美激情第二页| 欧美激情综合| 亚洲高清视频在线观看| 久久久久国色av免费看影院| 欧美专区在线观看| 国产精品美女久久久久久久| 日韩视频一区二区三区在线播放免费观看 | 亚洲性感激情| 亚洲小视频在线观看| 欧美激情精品久久久久久变态| 女人色偷偷aa久久天堂| 韩国一区二区三区在线观看| 欧美一区二区三区免费看| 欧美一级在线播放| 国产喷白浆一区二区三区| 午夜精品一区二区三区在线| 香蕉久久夜色精品国产| 国产欧美日韩不卡| 午夜视频一区| 久久网站免费| 亚洲国产中文字幕在线观看| 免费在线欧美视频| 亚洲人体大胆视频| 一区二区三区成人| 欧美午夜性色大片在线观看| 亚洲一区网站| 久久欧美中文字幕| 在线成人av.com| 欧美国产欧美综合| 日韩亚洲欧美一区二区三区| 亚洲综合国产| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品专区第二| 久久成人免费| 亚洲国产毛片完整版| 亚洲小视频在线观看| 国产精品入口麻豆原神| 亚洲欧美精品| 欧美高清在线一区| 亚洲一区日韩在线| 激情文学一区| 欧美日韩另类国产亚洲欧美一级| 一区二区三区视频在线播放| 久久国产毛片| 亚洲区免费影片| 国产精品一区二区你懂的| 久久久精品久久久久| 亚洲精品视频啊美女在线直播| 亚洲欧美日韩精品久久久| 狠狠色综合日日| 欧美日韩三区四区| 久久国产精品一区二区三区四区| 亚洲高清久久网| 久久精品成人欧美大片古装| 日韩视频一区二区三区在线播放免费观看 | 欧美色图一区二区三区| 欧美一区三区三区高中清蜜桃| 欧美国产日韩视频| 欧美一区二区三区在线视频| 亚洲国产欧美国产综合一区| 国产精品视频精品视频| 欧美高清视频一区| 久久精品成人| 中国成人在线视频| 欧美国产亚洲另类动漫| 欧美一区二区三区精品 | 狠狠做深爱婷婷久久综合一区| 欧美日本免费一区二区三区| 久久精品主播| 亚洲一本视频| 亚洲精品欧美极品| 免费欧美高清视频| 久久精品国产一区二区三| 亚洲一区国产精品| 亚洲精品在线三区| 亚洲国产另类久久久精品极度| 国产欧美一区二区精品婷婷| 欧美视频不卡| 欧美日韩免费网站| 欧美国产亚洲视频| 欧美91大片| 蜜桃av一区二区| 久久一区视频| 噜噜噜91成人网| 久久综合99re88久久爱| 久久另类ts人妖一区二区 | 亚洲大胆av| 欧美gay视频激情| 免费在线日韩av| 欧美 日韩 国产在线| 欧美xart系列高清| 免费成人小视频| 欧美激情一区二区三区在线视频观看 | 国产精品羞羞答答xxdd| 国产精品国产三级国产专播品爱网 | 亚洲欧美日韩国产中文| 亚洲综合色在线| 欧美一级视频精品观看| 欧美中文字幕在线| 久久精品免费电影| 看欧美日韩国产| 欧美成人一区二区三区片免费| 欧美肥婆在线| 亚洲精品在线视频| 亚洲一二三区在线| 欧美亚洲免费在线| 久久久噜噜噜久久人人看| 久久蜜臀精品av| 欧美激情一区二区三区全黄| 欧美日韩精品欧美日韩精品一| 国产精品国码视频| 韩国av一区二区三区| 亚洲黄色免费电影| 正在播放亚洲一区| 欧美在线一二三区| 欧美电影在线观看| 亚洲精品免费网站| 午夜精品一区二区三区四区| 久久亚洲欧美| 欧美视频一区二区三区在线观看| 国产精品成人免费视频| 国产一区二区三区精品久久久| 亚洲国产精品尤物yw在线观看| 在线视频欧美一区| 久久黄色小说| 亚洲国产综合91精品麻豆| 亚洲视频二区| 免费国产自线拍一欧美视频| 欧美午夜在线视频| 永久免费精品影视网站| 国产精品99久久久久久久vr| 久久久99精品免费观看不卡| 亚洲日本成人女熟在线观看| 亚洲欧洲99久久| 欧美噜噜久久久xxx| 国产一区二区丝袜高跟鞋图片| 亚洲美女一区| 老牛嫩草一区二区三区日本| 99伊人成综合| 麻豆freexxxx性91精品| 国产精品久久午夜| 日韩视频国产视频| 久久久青草青青国产亚洲免观| 亚洲九九精品| 你懂的视频欧美| 红桃视频成人| 久久电影一区| 在线一区亚洲|