• <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麻豆色欲 | 久久精品国产亚洲AV麻豆网站| 国产精品一区二区久久精品无码 | 99久久精品免费| 2021久久国自产拍精品| 久久久久99精品成人片直播| 国产69精品久久久久9999APGF| 亚洲国产香蕉人人爽成AV片久久| 欧美一级久久久久久久大| 精品国产青草久久久久福利| 久久精品国产一区二区三区| 久久国产综合精品五月天| 性做久久久久久久久老女人| 久久99这里只有精品国产| 久久久久人妻一区二区三区| 人妻精品久久无码区| 久久亚洲国产午夜精品理论片| 国产三级久久久精品麻豆三级 | 国产成人久久777777| 色天使久久综合网天天| 久久久国产精华液| 久久99国产精品久久99果冻传媒 | 久久天天躁狠狠躁夜夜avapp| 亚洲午夜久久久久妓女影院| 亚洲国产精品久久久久婷婷老年| 久久国产精品二国产精品| 久久久久久精品免费看SSS| 久久91精品国产91久久小草| 久久午夜无码鲁丝片午夜精品| 久久久久波多野结衣高潮| 久久精品国产一区| 久久久久久曰本AV免费免费| 久久综合综合久久狠狠狠97色88 | 久久婷婷色香五月综合激情 | 国产情侣久久久久aⅴ免费| 久久中文字幕视频、最近更新 | 久久人做人爽一区二区三区| 国产精品久久成人影院| 欧美黑人激情性久久| 一级做a爰片久久毛片16| 99久久精品国产一区二区 |