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

            在不同系統(tǒng)下分配大內(nèi)存的測(cè)試(c.c.l.c上一人的帖子,在老家網(wǎng)吧不方便實(shí)驗(yàn),記下啦,試試)

            今天在solaris下做這個(gè)測(cè)試

            測(cè)試代碼如下:
            #include <stdlib.h>
            #include <unistd.h>
            int main(){
                   void* p=malloc(512*1024*1024);
                   if(p==NULL) return -1;
                      sleep(10000000);
                         return 0;

            }


            然后我用g++ 4.3.2編譯
            g++-4.3.2 -o testm testm.c

            開(kāi)了5個(gè),開(kāi)到第6個(gè)的時(shí)候,malloc就返回-1了。可是,可是,令人驚奇的是
            這個(gè)時(shí)候,我無(wú)論是用vmstat還是用mdb看,我都還有大量的空閑的物理內(nèi)存
            >::memstat
            Page Summary                Pages                MB  %Tot
            ------------     ----------------  ----------------  ----
            Kernel                     144849               565   14%
            ZFS File Data               62043               242    6%
            Anon                       146323               571   14%
            Exec and libs                3640                14    0%
            Page cache                  34357               134    3%
            Free (cachelist)            35896               140    3%
            Free (freelist)            600734              2346   58%

            Total                     1027842              4015
            Physical                  1027841              4015
            這與我開(kāi)這幾個(gè)程序之前,沒(méi)有明顯的變化。(相比而下,在windows下,這個(gè)時(shí) 候系統(tǒng)已經(jīng)卡的快嗝屁了)

            然后我用ps來(lái)看
            # ps -eo pid,vsz,rss,args |grep testm
             1298 527292 1356 ./testm
             1309 4224 1256 grep testm
             1300 527292 1356 ./testm
             1302 527292 1356 ./testm
             1296 527292 1356 ./testm
             1304 527292 1356 ./testm

            # pmap 1296
            1296:    ./testm
            08046000       8K rwx--    [ stack ]
            08050000       4K r-x--  /tmp/testm
            08060000       8K rwx--  /tmp/testm
            08062000  524296K rwx--    [ heap ]
            FEB70000     320K r-x--  /lib/libm.so.2
            FEBCF000       8K rwx--  /lib/libm.so.2
            FECD0000      24K rwx--    [ anon ]
            FECE0000    1280K r-x--  /usr/lib/libc/libc_hwcap1.so.1
            FEE20000      28K rwx--  /usr/lib/libc/libc_hwcap1.so.1
            FEE27000       8K rwx--  /usr/lib/libc/libc_hwcap1.so.1
            FEE30000      52K r-x--  /usr/lib/libgcc_s.so.1
            FEE4C000       4K rwx--  /usr/lib/libgcc_s.so.1
            FEE50000       4K rwx--    [ anon ]
            FEE60000     856K r-x--  /usr/lib/libstdc++.so.6.0.10
            FEF45000     160K rwx--  /usr/lib/libstdc++.so.6.0.10
            FEF6D000      24K rwx--  /usr/lib/libstdc++.so.6.0.10
            FEF80000       4K r--s-  /var/ld/ld.config
            FEF90000       4K rwx--    [ anon ]
            FEFA0000       4K rw---    [ anon ]
            FEFB0000       4K rw---    [ anon ]
            FEFBE000     180K r-x--  /lib/ld.so.1
            FEFFB000       8K rwx--  /lib/ld.so.1
            FEFFD000       4K rwx--  /lib/ld.so.1
             total    527292K


            系統(tǒng)的確給這個(gè)進(jìn)程分配了地址空間(看它的heap有多大),但是壓根兒就沒(méi)有給 它分配物理內(nèi)存。我想不出的是,它依據(jù)什么來(lái)拒絕新的申請(qǐng)。
            由于環(huán)境有限,我沒(méi)有找到良好的環(huán)境在freebsd下重復(fù)這個(gè)實(shí)驗(yàn)。我在 freebsd.unix-center.net上做這個(gè)測(cè)試,但是把每個(gè)進(jìn)程分配的內(nèi)存縮小到64M, 然后開(kāi)了100個(gè)這樣的進(jìn)程,據(jù)估計(jì)至少需要6G的內(nèi)存,malloc一直都是成功的, 我的手酸了,懶得弄了。


            最有趣的在于這個(gè):
            #include <stdlib.h>
            #include <unistd.h>
            #include <string.h>

            int main(){
                   void* p=malloc(512*1024*1024);
                   if(p==NULL) return -1;
                memset(p,0,512*1024*1024);
                free(p);
                      sleep(10000000);
                         return 0;

            }

            用ps/pmap去看,事實(shí)證明,free函數(shù)根本就沒(méi)有釋放物理內(nèi)存。free是把malloc 得到的物理內(nèi)存還給了自己進(jìn)程,而不是還給了操作系統(tǒng)。
            在這一點(diǎn)上,freebsd是有差別的。執(zhí)行完free之后,rss明顯降了下來(lái)



            posted on 2010-02-18 20:01 楊帆 閱讀(441) 評(píng)論(0)  編輯 收藏 引用

            導(dǎo)航

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久九九久精品国产免费直播| 久久99国产一区二区三区| 97精品国产97久久久久久免费| 久久久久久国产精品免费无码| 色99久久久久高潮综合影院| 国内精品久久久久久久97牛牛| 亚洲中文字幕无码久久精品1| 亚洲欧洲中文日韩久久AV乱码| 中文成人久久久久影院免费观看| 99精品国产在热久久| 色欲综合久久中文字幕网 | 99久久久精品免费观看国产| 欧美黑人激情性久久| 国产精品99久久精品| 久久香蕉国产线看观看99| 国产精品久久久久乳精品爆| 国产精品女同一区二区久久| 欧美日韩成人精品久久久免费看| 三级三级久久三级久久 | 精品水蜜桃久久久久久久| 久久久久人妻一区精品| 国产69精品久久久久APP下载 | 亚洲精品tv久久久久| 国产成人精品综合久久久| 久久影院综合精品| 久久久久国产视频电影| 伊人久久大香线蕉AV色婷婷色| 国产午夜精品理论片久久影视| 香蕉99久久国产综合精品宅男自 | 77777亚洲午夜久久多喷| 久久99久久99精品免视看动漫| 亚洲精品美女久久777777| 国内精品久久久久久久亚洲| 国产精品丝袜久久久久久不卡 | aaa级精品久久久国产片| 久久久99精品成人片中文字幕| 久久精品国产亚洲AV不卡| 精品免费久久久久国产一区| 亚洲AV无码久久寂寞少妇| 久久国产精品免费一区二区三区 | 欧美久久久久久|