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

            qiezi的學(xué)習(xí)園地

            AS/C/C++/D/Java/JS/Python/Ruby

              C++博客 :: 首頁(yè) :: 新隨筆 ::  ::  :: 管理 ::
            先看一段代碼:

            void?main(){
            ????
            int[]?c?=?[1,2,3];
            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????c.length?
            =?2;
            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");


            ????c.length?
            =?3;
            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????c.length?
            =?4;
            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");
            }


            它輸出結(jié)果如下:

            B7D19FB0, B7D19FB4, B7D19FB8,
            B7D19FB0, B7D19FB4,
            B7D19FB0, B7D19FB4, B7D19FB8,
            B7D1CFA0, B7D1CFA4, B7D1CFA8, B7D1CFAC,

            可以看到前3行地址相同,后面一行地址不同。為什么?

            D語(yǔ)言的數(shù)組分配是內(nèi)存緊湊的,當(dāng)減小數(shù)組長(zhǎng)度減小時(shí),只需要修改切片大小而不需要重新分配。當(dāng)長(zhǎng)度變大時(shí),也會(huì)檢查原來(lái)的緩沖區(qū)是否夠大,以確定是否需要重新分配空間。注意第2次操作時(shí)把長(zhǎng)度恢復(fù)為原來(lái)大小時(shí),并非真的恢復(fù)了原來(lái)的狀態(tài),后面長(zhǎng)出來(lái)的元素會(huì)被初始化為默認(rèn)值。

            再來(lái)看一個(gè):

            void?main(){
            ????
            int[]?c?=?[1,2,3];
            ????
            int[]?d?=?c;

            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????
            foreach(inout?int?i;?d){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????d.length?
            =?2;

            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????
            foreach(inout?int?i;?d){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????d.length?
            =?4;

            ????
            foreach(inout?int?i;?c){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");

            ????
            foreach(inout?int?i;?d){
            ????????writef(
            &i);
            ????????writef(
            ",?");
            ????}
            ????writefln(
            "");
            }

            在執(zhí)行int[] d = c;以后,d的確是和c共享了存儲(chǔ)區(qū)。不過(guò)在改變d的長(zhǎng)度以后,它就和c分道揚(yáng)鑣了。所以int[] d = c不能理解為d是一個(gè)指向c的引用,它實(shí)際上創(chuàng)建了一個(gè)新的數(shù)組對(duì)象,但并不拷貝數(shù)組元素,它和int[] d = c[0 .. length]是等價(jià)的,都是數(shù)組切片操作。

            這個(gè)問(wèn)題讓我困惑不已。比如你用char[]表示一個(gè)單詞,用char[][]表示一行,char[][][]表示多行。如何引用這個(gè)單詞?你當(dāng)然可以每次使用lines[i][j],但如果處理步驟很多,這會(huì)不會(huì)看起來(lái)很頭大?

            看上去應(yīng)該這樣使用:

            char[][][]?lines;
            char[][]?line?=?lines[0];
            line.length?
            =?line.length?+?1;
            line[length?
            -?1]?=?",";

            可惜根據(jù)前面的結(jié)論,這將無(wú)法影響到lines。如果找不到一個(gè)引用類(lèi)型指向數(shù)組,有時(shí)候使用起來(lái)還真是很麻煩。看起來(lái)把Line/Word包裝成類(lèi)是個(gè)勉強(qiáng)湊合的主意。。。
            posted on 2006-10-07 16:21 qiezi 閱讀(959) 評(píng)論(4)  編輯 收藏 引用 所屬分類(lèi): D
            久久夜色精品国产噜噜亚洲AV | 久久久久久噜噜精品免费直播| 久久香蕉综合色一综合色88| 嫩草影院久久国产精品| 欧美亚洲日本久久精品| 久久精品亚洲中文字幕无码麻豆| 99精品久久久久久久婷婷| 麻豆av久久av盛宴av| 91亚洲国产成人久久精品| 久久久久久曰本AV免费免费| 亚洲午夜久久影院| 午夜精品久久久久久久| 国产精品青草久久久久福利99| 久久精品亚洲一区二区三区浴池| 人妻无码久久精品| 国产精品综合久久第一页| 99久久99久久| 久久国产精品无码一区二区三区 | 欧美日韩精品久久久久| 99久久精品免费看国产一区二区三区 | 久久久精品久久久久久 | 久久99精品国产99久久| 久久久久久伊人高潮影院| 久久精品亚洲精品国产欧美| 久久国产热精品波多野结衣AV| 77777亚洲午夜久久多喷| 久久成人小视频| 亚洲国产高清精品线久久| 国产精自产拍久久久久久蜜| 久久九九全国免费| 51久久夜色精品国产| 91久久精品国产91性色也| 99久久国产主播综合精品| 丰满少妇人妻久久久久久4| 91精品婷婷国产综合久久| 国产成人无码精品久久久久免费 | 91麻豆国产精品91久久久| 亚洲日本久久久午夜精品| 精品久久久久成人码免费动漫| 一极黄色视频久久网站| 久久久午夜精品福利内容|