• <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>
            隨筆 - 505  文章 - 1034  trackbacks - 0
            <2007年12月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345


            子曾經曰過:編程無他,唯手熟爾!

            常用鏈接

            留言簿(94)

            隨筆分類(649)

            隨筆檔案(505)

            相冊

            BCB

            Crytek

            • crymod
            • Crytek's Offical Modding Portal

            Game Industry

            OGRE

            other

            Programmers

            Qt

            WOW Stuff

            搜索

            •  

            積分與排名

            • 積分 - 911346
            • 排名 - 14

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            c++ builder 6中就是改變不了元素的值,不會編譯不過,執(zhí)行也不報錯。這玩意兒把我害慘了,害我找了好長時間。
            有空測試下vc7.1,vc8和c++ builder 2007,gcc

            寫了個測試程序vc7.1下居然能改變值:
            #include <vector>

            struct stUpdateItem
            {
                
            bool _downloadSucceeded;

                stUpdateItem() : _downloadSucceeded(
            false)
                {}
            };

            struct stDownItem
            {
                stUpdateItem
            * _pItem;
                
            bool          _bPack;

                stDownItem(stUpdateItem
            * item, bool bPack) : _pItem(item),_bPack(bPack)
                {}
            };

            typedef std::vector
            <stDownItem> tDownItems;

            int _tmain(int argc, _TCHAR* argv[])
            {
                tDownItems downList;

                stUpdateItem item1;
                stUpdateItem item2;

                stDownItem downItem1(
            &item1,true);
                stDownItem downItem2(
            &item2,false);

                downList.push_back(downItem1);
                downList.push_back(downItem2);

                
            for (tDownItems::const_iterator it = downList.begin(); it != downList.end(); ++it)
                {
                    
            if(true == it->_pItem->_downloadSucceeded)
                    {
                        std::cout 
            << "before change, found!" << std::endl;
                    }
                }

                
            for (tDownItems::const_iterator it = downList.begin(); it != downList.end(); ++it)
                {
                    it
            ->_pItem->_downloadSucceeded = true;
                }

                
            for (tDownItems::const_iterator it = downList.begin(); it != downList.end(); ++it)
                {
                    
            if(true == it->_pItem->_downloadSucceeded)
                    {
                        std::cout 
            << "after change, found!" << std::endl;
                    }
                }
                
            return 0;
            }

            執(zhí)行結果:
            after change, found!
            after change, found
            !
            posted on 2007-10-31 12:12 七星重劍 閱讀(1986) 評論(9)  編輯 收藏 引用 所屬分類: PL--c/c++

            FeedBack:
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 12:55 lovedday
            ....
            能改變值是正常的,const_iterator限定的是stDownItem,而不是stUpdateItem,而你改變的是stUpdateItem的值,當然可以。

            for (tDownItems::const_iterator it = downList.begin(); it != downList.end(); ++it)
            {
            it->_pItem->_downloadSucceeded = true;
            }  回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 13:42 lovedday
            不過我可能會這么寫:

            #include <malloc.h>
            #include <vector>

            using namespace std;

            typedef struct UPADTE_ITEM
            {
            bool down_succeeded;

            UPADTE_ITEM()
            {
            down_succeeded = false;
            }
            } *UPADTE_ITEM_PTR;

            typedef struct DOWN_ITEM
            {
            UPADTE_ITEM_PTR update_item;
            bool pack;

            DOWN_ITEM()
            {
            memset(this, 0, sizeof(*this));
            }
            } *DOWN_ITEM_PTR;

            int main()
            {
            vector<DOWN_ITEM> down_item_vec;

            UPADTE_ITEM item1;
            UPADTE_ITEM item2;

            DOWN_ITEM downItem1;
            downItem1.update_item = &item1;
            downItem1.pack = true;

            DOWN_ITEM downItem2;
            downItem2.update_item = &item2;
            downItem2.pack = false;

            down_item_vec.push_back(downItem1);
            down_item_vec.push_back(downItem2);

            for (vector<DOWN_ITEM>::const_iterator it = down_item_vec.begin(); it != down_item_vec.end(); ++it)
            {
            it->update_item->down_succeeded = true;
            }

            return 0;
            }  回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 13:46 lovedday
            也可能這么寫:

            #include <stdio.h>
            #include <malloc.h>

            typedef struct UPDATE_ITEM
            {
            bool down_succeeded;
            } *UPDATE_ITEM_PTR;

            typedef struct DOWN_ITEM
            {
            UPDATE_ITEM_PTR update_item;
            bool pack;

            DOWN_ITEM* next;
            } *DOWN_ITEM_PTR;

            DOWN_ITEM_PTR create_down_item(bool pack, bool down_succeeded)
            {
            DOWN_ITEM_PTR down_item = (DOWN_ITEM_PTR) malloc(sizeof(DOWN_ITEM));
            down_item->pack = pack;

            down_item->update_item = (UPDATE_ITEM_PTR) malloc(sizeof(UPDATE_ITEM));
            down_item->update_item->down_succeeded = down_succeeded;

            down_item->next = NULL;

            return down_item;
            }

            void free_all_down_item(DOWN_ITEM_PTR root_down_item)
            {
            DOWN_ITEM_PTR down_item_ptr = root_down_item;

            while(down_item_ptr)
            {
            if(down_item_ptr->update_item)
            free(down_item_ptr->update_item);

            DOWN_ITEM_PTR temp_ptr = down_item_ptr;
            down_item_ptr = down_item_ptr->next;

            free(temp_ptr);
            }
            }

            int main()
            {
            DOWN_ITEM_PTR down_item1 = create_down_item(true, false);
            DOWN_ITEM_PTR down_item2 = create_down_item(false, false);

            down_item1->next = down_item2;

            DOWN_ITEM_PTR down_item_ptr = down_item1;

            while(down_item_ptr)
            {
            down_item_ptr->update_item->down_succeeded = true;
            down_item_ptr = down_item_ptr->next;
            }

            free_all_down_item(down_item1);

            return 0;
            }  回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 15:20 lovedday
            你的代碼中涉及到內存的兩次分配。

              stDownItem downItem1(&item1, true); // 第一次分配
            stDownItem downItem2(&item2, false);

            downList.push_back(downItem1); // 第二次分配
            downList.push_back(downItem2);

            ---------------------------------------------------------------------------------------------------------

            而C風格僅涉及到一次內存分配。

            DOWN_ITEM_PTR down_item1 = create_down_item(true, false); // 就一次內存分配
            DOWN_ITEM_PTR down_item2 = create_down_item(false, false);

            down_item1->next = down_item2;
              回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 15:27 lovedday
            正確的做法應該是:

            downList.push_back(stDownItem(&item1, true));
            downList.push_back(stDownItem(&item2, false));
              回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 15:34 lovedday
            似乎也涉及到內存的兩次分配,免不了了,STL的push_back必然需要拷貝一次原始對象,從這種意義上說,可以不用vector,哈哈。
              回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-10-31 18:08 lovedday
            我做了個試驗,試驗條件是XP + VS 2005,在Release版本下測試,結果相當令人吃驚。

            malloc版本:

            #define ITEM_TIMES 1000000

            #include <malloc.h>

            #define NULL 0

            typedef struct UPDATE_ITEM
            {
            bool down_succeeded;
            } *UPDATE_ITEM_PTR;

            typedef struct DOWN_ITEM
            {
            UPDATE_ITEM_PTR update_item;
            bool pack;

            DOWN_ITEM* next;
            } *DOWN_ITEM_PTR;

            DOWN_ITEM_PTR create_down_item(bool pack, bool down_succeeded)
            {
            DOWN_ITEM_PTR down_item = (DOWN_ITEM_PTR) malloc(sizeof(DOWN_ITEM));
            down_item->pack = pack;

            down_item->update_item = (UPDATE_ITEM_PTR) malloc(sizeof(UPDATE_ITEM));
            down_item->update_item->down_succeeded = down_succeeded;

            down_item->next = NULL;

            return down_item;
            }

            void free_all_down_item(DOWN_ITEM_PTR root_down_item)
            {
            DOWN_ITEM_PTR down_item_ptr = root_down_item;

            while(down_item_ptr)
            {
            if(down_item_ptr->update_item)
            free(down_item_ptr->update_item);

            DOWN_ITEM_PTR temp_ptr = down_item_ptr;
            down_item_ptr = down_item_ptr->next;

            free(temp_ptr);
            }
            }

            int main()
            {
            DOWN_ITEM_PTR first, last, ptr;

            for(int i = 0; i < ITEM_TIMES; i++)
            {
            if(i == 0)
            {
            first = create_down_item(true, false);
            last = first;
            }
            else
            {
            ptr = create_down_item(true, false);
            last->next = ptr;

            last = ptr;
            }
            }

            while(1)
            ;

            free_all_down_item(first);

            return 0;
            }

            vector版本:

            #include <vector>

            using namespace std;

            typedef struct UPADTE_ITEM
            {
            bool down_succeeded;

            UPADTE_ITEM()
            {
            down_succeeded = false;
            }
            } *UPADTE_ITEM_PTR;

            typedef struct DOWN_ITEM
            {
            UPADTE_ITEM_PTR update_item;
            bool pack;

            DOWN_ITEM()
            {
            update_item = NULL;
            pack = false;
            }

            DOWN_ITEM(UPADTE_ITEM_PTR _update_item, bool _pack)
            {
            update_item = _update_item;
            pack = _pack;
            }
            } *DOWN_ITEM_PTR;

            int main()
            {
            vector<DOWN_ITEM> down_item_vec;

            UPADTE_ITEM_PTR update_item_list = new UPADTE_ITEM[ITEM_TIMES];

            for(int i = 0; i < ITEM_TIMES; i++)
            down_item_vec.push_back(DOWN_ITEM(&update_item_list[i], true));

            while(1)
            ;

            delete[] update_item_list;

            return 0;
            }

            改變ITEM_TIMES的值以改變迭代次數(shù)。

            內存消耗比較:

            迭代1000次: malloc - 868k vector - 796K
            迭代10000次 : malloc - 1784k vector - 916k
            迭代100000次 : malloc - 10956k vector - 2000k
            迭代1000000次 : malloc - 102648k vector - 10008k

            vector版本內存消耗更少,我想應該是多次malloc導致內存消耗劇增,而vector只在必要的時候才重新分配內存。
            而malloc版本在代碼中所涉及的指針操作也相當煩瑣。
              回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-11-01 15:11 重劍
            @lovedday
            呵呵,你真有空啊。居然回復了這么多。
            受益匪淺,只是不喜歡c風格的代碼。。。  回復  更多評論
              
            # re: 用std::vector的const_iterator對元素賦值會怎樣? 2007-11-01 19:04 lovedday
            哈哈,獻丑了。  回復  更多評論
              
            国产毛片久久久久久国产毛片| 色8久久人人97超碰香蕉987| 综合网日日天干夜夜久久| 国产成人香蕉久久久久| 狠狠色丁香婷综合久久| 国产精品美女久久久久| 久久99久久99精品免视看动漫| 久久亚洲精品成人无码网站| 久久久久久久91精品免费观看| 久久精品国产AV一区二区三区| 性做久久久久久久久浪潮| 久久综合亚洲色一区二区三区| 久久只这里是精品66| 亚洲人成精品久久久久| 亚洲AV无一区二区三区久久| 精品国产乱码久久久久久1区2区 | 亚洲av日韩精品久久久久久a| 国产精品99久久久久久宅男小说 | 久久亚洲精品无码aⅴ大香| 怡红院日本一道日本久久 | AAA级久久久精品无码区| 精品无码久久久久久久久久| 亚洲欧美成人久久综合中文网 | 女人香蕉久久**毛片精品| 国产亚州精品女人久久久久久 | 97精品伊人久久久大香线蕉| 热re99久久6国产精品免费| 国产精品久久久久aaaa| 久久91精品综合国产首页| 综合网日日天干夜夜久久| 久久国产乱子伦精品免费强| 色欲综合久久躁天天躁| 亚洲国产精品无码久久一线| 久久精品一区二区三区不卡| 久久久久这里只有精品| 久久婷婷五月综合国产尤物app| 91精品国产91热久久久久福利| 国产精品久久久久免费a∨| 久久久精品午夜免费不卡| 久久久久久精品免费免费自慰| 国内精品久久人妻互换|