• <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>
            隨筆-159  評論-223  文章-30  trackbacks-0
               最近在工作中,寫一計算桿塔絕緣子中心點的GPS坐標程序時,定義了一結構,里面用到了string類型來存儲桿塔所屬線路號、桿塔號,桿塔模型名稱。代碼如下:
             1/*
             2  @brief 桿塔信息結構
             3*/

             4typedef struct   _TOWER_INFO
             5{
             6       string    strLineNo;           ///< 線路號 
             7       string    strTowerNo;         ///< 桿塔號
             8       string    strTowerType;     ///< 桿塔類型
             9       double  dDangDistance;    ///< 檔距
            10      double  dHCHeight;           ///< 呼稱高
            11      double  dLongitude;          ///< 經度
            12      double  dLatitude;              ///< 緯度
            13      double  dAltitude;              ///< 海拔高度
            14      double  dLineCorners;      ///< 線路轉角 
            15      long      lCornerDirection;  ///< 左轉還是右轉: 0不轉, 1左轉, 2右轉
            16      vector<INSULATOR_INFO::CENTER_POINT_INFO>  vecInsulatorCenterPointInfo; ///< 桿塔所有絕緣子中心點信息
            17       _TOWER_INFO() { memset(this0sizeof(_TOWER_INFO)); }       //該行代碼可能會引起string內存泄露
            18
            19}
            TOWER_INFO,*PTOWER_INFO;
               在后面對該結構的string型變量有賦值操作, 代碼如下
            1   ......
            2       TOWER_INFO cur_tower_center_info;
            3   cur_tower_center_info.strLineNo = sheetLine->Cell(i, 2)->GetText(); //調度碼
            4   cur_tower_center_info.strTowerNo = sheetLine->Cell(i, 7)->GetText(); //桿塔號
            5   cur_tower_center_info.strTowerType = sheetLine->Cell(i, 8)->GetText(); //桿塔類型
            6      ......
               運行程序,待程序結束后,發現有內存泄露,提示信息如下
             1Detected memory leaks!
             2Dumping objects ->
             3{235250} normal block at 0x01774A6016 bytes long.
             4 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
             5{235237} normal block at 0x01774CB016 bytes long.
             6 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
             7{235234} normal block at 0x01774A1016 bytes long.
             8 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
             9{235184} normal block at 0x0177420016 bytes long.
            10 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
            11{235171} normal block at 0x0177445016 bytes long.
            12 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
            13{235168} normal block at 0x017741B016 bytes long.
            14 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
            15{235118} normal block at 0x017739A016 bytes long.
            16 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
            17{235105} normal block at 0x01773BF016 bytes long.
            18 Data: <                > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD 
            19..
               經過一番源代碼跟蹤調試后,發現原因在于TOWER_INFO結構體的構造函數內調用了memset(this, 0, sizeof(_TOWER_INFO);使得string內部指針_Bx._Ptrr值為0,_Myres為0,在這種情況下當string對象被賦值為小字符串(字節數包括結束符小于等于16的字符串)時,因新申請的內存在后來得不到釋放,所以這塊內存被泄露了,根據string類內存管理算法(ms vc版本)得知這塊內存大小總是16個字節.但當被賦值為大字符串(字節數包括結束符大于16的字符串)時,反而沒有內存泄露,這是因為新申請的內存在析構或下次賦值時總能被釋放.
              從該泄露問題的分析解決過程中,總結得到規律:不要輕易零初始化string, vector等stl標準容器及具有動態內存管理的類。
            posted on 2009-08-07 01:31 春秋十二月 閱讀(7732) 評論(19)  編輯 收藏 引用 所屬分類: C/C++

            評論:
            # re: std::string內存泄露問題之分析解決 2009-08-07 06:24 | maomi
            凡是初始化有非零賦值的都有問題,和有沒有動態內存管理無關吧
            vector 似乎沒事,都是零初值  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 07:44 | shaker(太子)
            問題是你為什么要用memset去操作一個對象?  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 08:32 | 周龍亭
            問題在于你用memset操作C++對象  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決[未登錄] 2009-08-07 08:56 | christanxw
            樓主難道就不知道C++類構造函數不要隨便使用memset去初始化對象嗎?一切問題都是你的memset引起的,跟string沒關系。  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 09:20 | evoup
            這都敢用memset this,汗~  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 09:36 | abettor
            作為博主忠實的粉絲,為了擁護博主的文章,我也曾經犯過幾乎相同的錯誤。
            我當時是在VC6里把含有CString型成員的結構體給memset了。  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 12:39 | 陳梓瀚(vczh)
            就算是struct,我也會寫一個構造函數,從而代替memset的……其實在使用的過程中,memset基本沒用處  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 12:53 | test
            memset(this, 0,。。本身沒問題,但是前提條件是它內部成員是你可控的。這是c程序員向c++程序員轉換的時候的一個階段。。。  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 13:10 | CY
            樓上說得好。
            應該總結:不要從內存級別改變對象級別的東西  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 14:15 | zdhsoft
            不要把C的習慣帶入C++
              回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-07 20:33 | 空明流轉
            變成批判大會了。。。  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-08 16:45 | lovelypig
            標題黨  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-11 10:51 |
            。。。。樓主太NB了  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-08-13 09:43 | bigzhu
            不要混用c和c++
            不然就是這樣悲慘的遭遇..
            樓主改下題目吧
            不要把泄漏賴到string頭上...  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2009-11-15 11:12 | calabash
            我也遇到了同樣的問題,哎,調查半天。。。

            //應該總結:不要從內存級別改變對象級別的東西
            這個很有道理  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決[未登錄] 2010-06-18 09:21 | kuafoo
            這個屬于使用不當  回復  更多評論
              
            # re: std::string內存泄露問題之分析解決 2011-08-26 12:28 | 匿名
            我也遇到同樣的問題:
            我聲明一個結構體,如下:
            struct A
            {
            int id;
            string name;
            };

            A a;
            a.id = 9;
            a.name = "tom";
            想把該結構體內容拷貝到char* buff中,用memcpy(buff,&a,sizeof(a));

            在此過程中,如果a.name長度小于16,結果與期望一致,但是如果a.name的長度大于16,則出現問題,通過調試發現再把buff中的內容拷貝回a,則顯示a的name屬性是不可讀內容。  回復  更多評論
              
            # re: basic_string內存泄露問題之分析解決 2012-04-11 10:50 | CCW
            想把該結構體內容拷貝到char* buff中,用memcpy(buff,&a,sizeof(a));
            是memcpy(buff,&a.name,sizeof(a.name));吧
            @匿名  回復  更多評論
              
            # re: basic_string內存泄露問題之分析解決 2014-09-09 17:18 | 席大軍
            如果 吧struct中的string都換成char數組,可以用memset嗎?  回復  更多評論
              
            亚洲日韩欧美一区久久久久我| 精品国产乱码久久久久久郑州公司 | 色综合久久久久综合体桃花网| 伊人久久综合无码成人网| 久久青青草原亚洲av无码app| 久久美女人爽女人爽| 欧美精品一区二区久久 | 激情伊人五月天久久综合| 大美女久久久久久j久久| 2021国内久久精品| 国产精品久久久久久久久久免费| 超级97碰碰碰碰久久久久最新| 国产精品久久久久久久久| 亚洲国产成人精品久久久国产成人一区二区三区综 | yy6080久久| www亚洲欲色成人久久精品| 久久人人爽人人爽人人片AV东京热| AAA级久久久精品无码片| 中文字幕精品久久久久人妻| 久久婷婷国产麻豆91天堂| 亚洲色大成网站www久久九| 久久九九久精品国产| 久久精品成人免费网站| 人妻精品久久久久中文字幕69| 欧美大战日韩91综合一区婷婷久久青草 | 亚洲AV无码一区东京热久久| 久久综合视频网站| 久久亚洲精品无码播放| 国产L精品国产亚洲区久久| 99久久中文字幕| av无码久久久久不卡免费网站| 国内精品久久久久影院老司| 久久精品亚洲精品国产欧美| 国产精品久久久久乳精品爆| 成人资源影音先锋久久资源网| 国产精品美女久久久久久2018| 久久精品国产精品亚洲精品 | 亚洲精品乱码久久久久久按摩 | 99久久精品免费看国产免费| 亚洲国产成人久久精品动漫| 国产午夜精品理论片久久|