• <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>
            隨筆 - 13  文章 - 36  trackbacks - 0
            <2009年3月>
            22232425262728
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(2)

            隨筆檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

                這陣子不怎么忙,閑時把Effective c++,more Effective c++, Exceptional c++,more Exceptional c++在復習了下,根據c++ primer 中提到設計一個string 類型需要的功能,編了一個異常安全的string 類。類基于shared_ptr<char>實現,使用的是vc9的shared_ptr(發現vc9的shared_ptr的reset函數可能有問題,看boost的源碼,覺得boost的是沒有問題的。大家可以試試。),大家也可以使用boost的shared_ptr。一直都是關注大家的文章,今天終于寫下了自己的文章了。咱們博客有不少強人,希望大家提點建議。

            1,頭文件: myString.h

            myString.h


            2,實現文件:myString.cpp

            myString.cpp

             

            3,測試代碼:

            測試代碼

             

            4,代碼打包地址:/Files/Alex-Lee/myString.rar 

            posted on 2009-03-18 09:12 Alex-Lee 閱讀(1828) 評論(12)  編輯 收藏 引用

            FeedBack:
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 10:40 wingfire
            不得不說,這個實現糟糕的一塌糊涂。邏輯都不正確,談什么異常安全?  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 10:49 Alex-Lee
            @wingfire

            兄弟,能說清楚點嗎?有好的資料推薦下?  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 12:11 megax
            這個實現沒有自己的內存管理,根本就無法使用棧上的字符串,shared_ptr的作用,作者還要好好看看。字符串一個很重要的內容就是內存管理,CopyOnWrite之類的技巧是必須的。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 16:29 yindf
            你這個實現太汗了

            myString::myString(const char *cstr)
            :data_(const_cast<char*>(cstr))
            {
            }

            你這樣直接就把外面傳來的指針放到shared_ptr,如果我這么么構造:

            myString("abc");

            那靜態的字符串常量難道能被shared_ptr釋放掉。。。

            BTW: 我只看了前面幾行,建議你再仔細看看,而且建議別說異常安全,異常安全好說難做,非常難。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 20:35 陳梓瀚(vczh)
            整個都是錯的,應當扔掉重寫。你自己也應當好好學習一下什么是C++才行。

            1:字符串的char*要自己創建自己刪除,別人給你char*你也得復制內容而不是復制指針。
            2:shared_ptr<char>不是給你放char數組而是char指針的。
            3:equal比較兩個指針無意義。
            4:速度起見,你應當總是維護一個int length而不是在length()里面strlen,因為length還有很多其他用處。
            5:考慮引用計數。
            6:功能太少。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-18 20:36 陳梓瀚(vczh)
            7:沒有看到任何跟異常安全有關的東西。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 10:40 夢在天涯
            此地高手多也!

            大家的意見還是很好的!  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 12:31 null
            @陳梓瀚(vczh)
            equal比較兩個指針,還是有意義的  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 14:50 Alex-Lee
            @yindf
            @陳梓瀚(vczh)

            首先謝謝大家給的意見,果然高手如云。再次拜服。
            兩位意見不錯,特別是構造函數那個錯誤比較大。這個確實是疏忽了。Exceptional c++中的NewCopy函數可以借用解決這個問題。

            另外,異常安全有三個等級,依次是無資源泄露,狀態一致,無異常拋出。一般能實現到狀態一致是很不錯了。
            我談談自己設計的初衷。
            1,像PIMP/COW實現太過復雜,啰嗦,不太喜歡。
            2,使用shared_ptr是因為,智能指針本身就是為了防止原生指針資源泄露問題而設計的,這樣就達到了無資源泄露的基本保證。就不需要處理原始指針問題。
            因此,我的設計就是保證狀態一致問題。也即是說,我設計這個類就是只要保證狀態一致即可。如果確實使用char*這樣的原生指針作為數據成員,那么這個類確實需要重新設計,這毋庸置疑。

            3,equal()函數自己也有些疑惑,到底是只要兩個字符串的值相等就行還是需要指向的是同一塊字符串內存呢?或者myString對象本身就應該是同一個對象?4,關于維護length長度問題,由于使用shared_ptr實現,因此,就不需要維護 length成員。否則,如果使用shared_ptr與length,還需要維護兩者之間的一致。當然,如果使用原生指針char*而不是使用shared_ptr,那么提供length成員變量是應該。
            5,由于使用shared_ptr,因此就不需要引用計數了。shared_ptr本身是引用計數的實現。myString封裝中沒有其他的成員,不涉及占過多內存的問題。


            這篇文章的發表,確實是讓我學習到了不少東西,再次謝謝大家,希望大家多提意見,這樣才能快速成長。
              回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 16:06 陳梓瀚(vczh)
            @null
            設計string的其中一個目的就是將char*封閉起來,獲得并操作char*的唯一辦法就是使用類似GetBuffer()的東西。因此equal的存在是不合理的。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 16:08 陳梓瀚(vczh)
            @Alex-Lee
            1:shared_ptr使用delete而不是delete[]刪除你的東西。這是有問題的。所以你必須自己實現。
            2:shared_ptr沒有copy-on-write,因為這是不可能的,所以你必須自己實現。
            3:由于length的重要性,你必須寫test case來保證你維護了他們的一致性。  回復  更多評論
              
            # re: 自己實現的一個基于異常安全的string類 2009-03-19 16:32 Alex-Lee
            @陳梓瀚(vczh)

            謝謝。shared_ptr使用delete的話,這樣操作數組確實是問題。因此,對于設計數組類型的安全類,不能選用shared_ptr這么處理,這樣看來,類設計時選用shared_ptr就是錯誤的。這樣,終于搞明白了,為什么開始有人說這個設計糟糕透頂了。這個設計確實是有問題的。這次,印象深刻,徹底糾正了思想上的錯誤。
              回復  更多評論
              
            久久久久人妻一区精品性色av| 久久久青草青青国产亚洲免观| 久久久中文字幕| 伊人久久久AV老熟妇色| 性做久久久久久久久| 88久久精品无码一区二区毛片| 久久久噜噜噜www成人网| 中文字幕精品久久| 久久综合九色综合久99| 久久久久18| 婷婷久久综合九色综合绿巨人| 久久综合九色综合欧美就去吻| AAA级久久久精品无码区| 国产毛片久久久久久国产毛片| 韩国三级中文字幕hd久久精品 | 国产精品一区二区久久精品无码| 久久se精品一区精品二区| 久久综合中文字幕| 欧美大战日韩91综合一区婷婷久久青草 | 精品视频久久久久| 国产综合精品久久亚洲| 精品久久久无码中文字幕天天| 久久精品国产黑森林| 亚洲欧美一区二区三区久久| 久久久www免费人成精品| 久久人爽人人爽人人片AV| 香港aa三级久久三级| 久久午夜福利电影| 久久香蕉超碰97国产精品| 久久国产精品一区| 亚洲AV日韩精品久久久久久| 四虎国产永久免费久久| 亚洲欧洲中文日韩久久AV乱码| 久久精品国产99久久无毒不卡| 99久久国产综合精品成人影院| 久久综合偷偷噜噜噜色| 青青青青久久精品国产| 久久精品国产亚洲AV不卡| 91精品免费久久久久久久久| 中文字幕久久精品无码| 久久久久这里只有精品|