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

            鍵盤上的舞者

            My Email: marckywu@gmail.com
            隨筆 - 19, 文章 - 0, 評論 - 3, 引用 - 0
            數據加載中……

            二維數組new小結(轉載)

            發信人: nichloas (nil), 信區: CPlusPlus
            標  題: [FAQ] 二維數組new小結
            發信站: BBS 水木清華站 (Sat Jun  7 15:27:42 2003), 轉信

            1.
                A (*ga)[n] = new A[m][n];
                ...
                delete []ga;
            缺點:n必須是已知
            優點:調用直觀,連續儲存,程序簡潔(經過測試,析構函數能正確調用)

            2.  A** ga = new A*[m];
                for(int i = 0; i < m; i++)
                    ga[i] = new A[n];
                ...
                for(int i = 0; i < m; i++)
                    delete []ga[i];
                delete []ga;
            缺點:非連續儲存,程序煩瑣,ga為A**類型
            優點:調用直觀,n可以不是已知

            3.  A* ga = new A[m*n];
                ...
                delete []ga;
            缺點:調用不夠直觀
            優點:連續儲存,n可以不是已知

            4.  vector<vector<A> > ga;
                ga.resize(m);                       //這三行可用可不用
                for(int i = 1; i < n; i++)          //
                    ga[i].resize(n);                //
                ...

            缺點:非連續儲存,調試不夠方便,編譯速度下降,程序膨脹(實際速度差別不大)
            優點:調用直觀,自動析構與釋放內存,可以調用stl相關函數,動態增長

            5.  vector<A> ga;
                ga.resize(m*n);
            方法3,4的結合


            6. 2的改進版(Penrose提供,在此感謝)
                A** ga = new A*[m];
                ga[0] = new A[m*n];
                for(int i = 1; i < m; i++)
                    ga[i] = ga[i-1]+n;
                ...
                delete [] ga[0];
                delete [] ga;
            缺點:程序煩瑣,ga為A**類型
            優點:連續儲存,調用直觀,n可以不是已知



            附:1,2,3,6還有對應的malloc-free版本
            個人推薦1和4,2可以用4來代替,3,5調用太煩瑣,畢竟源程序是拿來看的
            不是拿來運行的


            下面是一些錯誤和沒成功的版本

            1. A* ga = new A[m][n];
              必然錯誤

            2. vector<A[n]> ga;
               ga.resize(m);

               gcc 3.2下編譯失敗,不知道其它編譯器效果如何
               也不知道標準是否允許

            我知道的就這些,歡迎大家補充,指正




            --



            --

            ※ 來源:·BBS 水木清華站 smth.org·[FROM: 162.105.216.213]
            ※ 修改:·devilphoenix 于 Sep  5 18:10:57 修改本文·[FROM: 211.99.222.*]

            posted on 2009-12-06 22:01 Marcky 閱讀(251) 評論(0)  編輯 收藏 引用

            久久美女网站免费| 久久亚洲欧洲国产综合| 久久性精品| 欧美激情精品久久久久久久九九九 | 亚洲国产精品无码久久九九| 久久久久亚洲av毛片大 | 久久久久人妻一区二区三区| 亚洲精品国精品久久99热一| 久久久久久毛片免费播放| 久久无码人妻一区二区三区午夜| 精品免费久久久久久久| 国产L精品国产亚洲区久久| 18禁黄久久久AAA片| 四虎国产精品免费久久5151| 国产成人综合久久精品红| 亚洲欧美精品伊人久久| 免费精品久久天干天干| 国产成人久久精品二区三区| 精品无码久久久久国产动漫3d| 婷婷综合久久狠狠色99h| 色综合合久久天天给综看| 丁香狠狠色婷婷久久综合| 亚洲中文字幕无码久久2017| 精品国产一区二区三区久久蜜臀| 无码人妻少妇久久中文字幕蜜桃| 久久人搡人人玩人妻精品首页| 久久青青草原亚洲av无码app| 一本久久精品一区二区| 久久久久国产视频电影| 久久青青草原国产精品免费| 久久久久高潮综合影院| 伊人久久大香线蕉无码麻豆| 日本精品久久久中文字幕| 激情伊人五月天久久综合| 亚洲AV日韩精品久久久久| 久久乐国产综合亚洲精品| 久久一区二区三区99| 久久激情亚洲精品无码?V| 精品国产综合区久久久久久| 久久青草国产精品一区| 久久精品国产99国产精品澳门|