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

            国产精品成人久久久| 久久精品中文字幕有码| 亚洲综合伊人久久大杳蕉| 久久精品国产亚洲av高清漫画| 午夜精品久久久久久99热| 一本大道久久a久久精品综合| 久久久久久青草大香综合精品 | 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产精品无码久久综合| 狠狠精品久久久无码中文字幕 | 久久精品国产亚洲网站| 久久综合视频网站| 国内精品久久久久久久97牛牛| 精品久久久久一区二区三区| 一本久久a久久精品vr综合| 99久久99久久精品国产片果冻| 久久精品成人欧美大片| 精品国产一区二区三区久久| 久久亚洲中文字幕精品一区| 国产精品九九久久免费视频| 国产精品久久久亚洲| 久久WWW免费人成一看片| 久久精品国产99国产精品| 久久精品国产久精国产| av无码久久久久不卡免费网站| 一本久久免费视频| 久久黄视频| 久久久久久久综合综合狠狠| 一本一道久久精品综合| 久久精品国产影库免费看| 99久久国产宗和精品1上映 | 无码人妻少妇久久中文字幕| 久久精品亚洲乱码伦伦中文| 国产精品内射久久久久欢欢| 久久九九亚洲精品| 99久久亚洲综合精品成人| 伊人色综合久久| 久久99亚洲综合精品首页| 久久精品无码免费不卡| 久久五月精品中文字幕| 亚洲人成无码www久久久|