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

            大規模高性能網絡服務器編程 大型游戲服務器編程


            大規模高性能網絡服務器編程 大型游戲服務器編程 完成端口模型 TCP UDP P2P 網絡編程

                       C++博客 | 首頁 | 發新隨筆 | 發新文章 | 聯系 | 聚合 | 管理

                          

            STL容器使用之二:deque


            本文原創發表地址為:http://www.shnenglu.com/kusamba/archive/2010/09/17/126895.html,轉載請保留原鏈接,謝謝!


            deque的數據結構示意圖:

            技術要點:
            隨機訪問每個元素,所需要的時間為常量。
            在開頭和末尾增加元素所需時間與元素數目無關,在中間增加或刪除元素所需時間隨元素數目呈線性變化。
            可動態增加或減少元素,內存管理自動完成,不提供用于內存管理的成員函數。


            參考代碼:
             1 /************************************************************************
             2 * deque:
             3 *    1, 分塊分配空間,非順序存儲,隨機訪問是通過復雜的iterator實現
             4 *    2, 在前后插入數據時間復雜度為O(1)
             5 *    3, 迭代器失效:
             6 *       If an element is inserted into an empty sequence, or if an element is 
             7        erased to leave an empty sequence, then iterators earlier returned 
             8        by begin and end become invalid.
             9 
            10        If an element is inserted at the first position of the deque, 
            11        then all iterators, but no references, that designate existing 
            12        elements become invalid.
            13 
            14        If an element is inserted at the end of the deque, then end and all 
            15        iterators, but no references, that designate existing elements become invalid.
            16 
            17        If an element is erased at the front of the deque, only that iterator 
            18        and references to the erased element become invalid.
            19 
            20        If the last element is erased from the end of the deque, only that 
            21        iterator to the final element and references to the erased element become invalid.
            22 
            23        Otherwise, inserting or erasing an element invalidates all iterators and references.
            24 
            25 *    by Kusamba@126.com    http://www.shnenglu.com/kusamba
            26 */
            27 void deque_test()
            28 {
            29     deque<int> dqInt;
            30 
            31     int nSize = dqInt.size();
            32     int nMaxSiz = dqInt.max_size();
            33 
            34     dqInt.resize(100);
            35     dqInt.resize(102);
            36     
            37     /**
            38     * push_back
            39     */
            40     for (int i = 0; i < 10++i)
            41     {
            42         dqInt[i] = i + 1;
            43     }
            44     for (int i = 0; i < 10++i)
            45     {
            46         dqInt.push_back(i + 11);
            47     }
            48 
            49     /**
            50     * insert
            51     */
            52     for (deque<int>::iterator it = dqInt.begin(); it != dqInt.end();)
            53     {
            54         if (*it % 3 == 0//在3的倍數的元素后面插入100
            55         {
            56             it = dqInt.insert(it + 1100);
            57         } 
            58         else
            59         {
            60             ++it;
            61         }
            62     }
            63 
            64     /**
            65     * erase
            66     */
            67     for (deque<int>::iterator it = dqInt.begin(); it != dqInt.end();)
            68     {
            69         if (*it == 4)
            70         {
            71             it = dqInt.erase(it);
            72         } 
            73         else
            74         {
            75             ++it;
            76         }
            77     }
            78 
            79     /**
            80     * traverse
            81     */
            82     printf("print deque: ");
            83     for (int i = 0; i < dqInt.size(); ++i)
            84     {
            85         printf("%d ", dqInt[i]);
            86     }
            87     printf("\n");
            88 
            89     /**
            90     * pop
            91     */
            92     while (!dqInt.empty())
            93     {
            94         int nItemVal = dqInt.front();
            95         dqInt.pop_front();
            96     }
            97 }


            posted on 2010-09-17 17:19 iKusamba 閱讀(1684) 評論(0)  編輯 收藏 引用 所屬分類: C++技術

            公告

            導航

            隨筆分類

            最新隨筆

            最新評論

            閱讀排行榜

            亚洲狠狠久久综合一区77777| 久久久久国产精品嫩草影院| 丁香五月网久久综合| 日韩影院久久| 久久久久无码精品国产不卡| 久久久婷婷五月亚洲97号色| 国产成人精品综合久久久| 国内精品伊人久久久久妇| 久久久久久人妻无码| 精品欧美一区二区三区久久久| 精品伊人久久久| 精品久久久久久国产牛牛app| 亚洲人成伊人成综合网久久久| 亚洲伊人久久大香线蕉苏妲己| 久久夜色精品国产噜噜亚洲a| 久久精品国产99国产精偷 | 四虎国产精品免费久久久 | 久久久久久久久无码精品亚洲日韩| 伊人久久大香线蕉影院95| 久久久久久精品免费免费自慰| 国产精品伊人久久伊人电影 | 漂亮人妻被中出中文字幕久久| 国内精品久久久久国产盗摄| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久影院综合精品| 国产激情久久久久影院老熟女| 久久综合给合久久狠狠狠97色| 天天综合久久一二三区| 国内精品久久久久久久久| 久久99久久99小草精品免视看| 色偷偷偷久久伊人大杳蕉| 久久久亚洲AV波多野结衣| 久久亚洲精品国产精品婷婷| 久久综合狠狠色综合伊人| 国产三级精品久久| 久久精品无码一区二区三区| 亚洲国产精品无码久久| 精品久久久久久国产| 久久婷婷五月综合97色直播| 亚洲伊人久久综合中文成人网| 久久综合久久鬼色|