• <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 閱讀(262) 評論(0)  編輯 收藏 引用

            久久久久久青草大香综合精品| 久久夜色tv网站| 国产A级毛片久久久精品毛片| 99久久免费国产精品特黄| 国产成人精品综合久久久| 国产精品久久久久无码av| 久久久久久久久久久免费精品| 国产精品99久久久久久宅男小说| 国产精品无码久久久久久| 人人狠狠综合久久亚洲| 久久亚洲欧美国产精品| 久久露脸国产精品| 91精品婷婷国产综合久久| av色综合久久天堂av色综合在| 9999国产精品欧美久久久久久 | 久久99精品国产麻豆宅宅| 久久夜色精品国产| 麻豆精品久久精品色综合| 久久久久亚洲AV无码专区首JN| 一级做a爰片久久毛片16| 囯产精品久久久久久久久蜜桃| 国产69精品久久久久99尤物| 久久精品国产亚洲av影院| 亚洲国产婷婷香蕉久久久久久| 久久99国产精品久久99| aaa级精品久久久国产片| 青草国产精品久久久久久| 狠狠色丁香久久婷婷综合图片| 激情五月综合综合久久69| 久久ww精品w免费人成| 久久香蕉国产线看观看精品yw| 久久午夜夜伦鲁鲁片免费无码影视| 国产精品无码久久久久| 精品多毛少妇人妻AV免费久久| 99久久免费国产精精品| 久久国产免费观看精品| 69国产成人综合久久精品| 91精品婷婷国产综合久久| 久久亚洲欧美日本精品| 国产成人香蕉久久久久| 久久国产精品二国产精品|