• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

            博客搬家了哦,請移步
            叫我abc

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 303613
            • 排名 - 84

            最新評論

            閱讀排行榜

            前段時間寫了不少代碼,不是隨手寫練習,而是一整個項目做下來的,于是就有了一些以前不曾有的心得,不過都來源于《有效C++》之類的書,只不過自己親身經歷之后體會更深刻一點。
            1 ?一個類的成員變量實在太多的時候,對這些變量進行分類包裝吧。我寫過一個類,里面有很多數據成員,多得在編寫該類的功能函數的時候常常要去頭文件回顧各個變量的名稱和意義。后來覺得太難受,就將這些變量分類,一個類別是關于運動變量的,一個類別是關于攝像機運動的,還有一個類別是物理規則方面的,也就是說我在該類內部聲明了3個struct,并實例化了他們。
            個人的感覺是,對于煩雜的東西進行適當的歸類,便于管理。
            2? Log類。一個項目是要時刻注意將一些運行信息進行輸出的,那些信息對調試具有不可取代的意義,透明化的意義就在于此。事實上,當編寫的項目涉及到第三方庫的時候,很有可能依靠帶斷點的debug運行已經極為耗時,所以LogOut必要的信息是有益的,不要吝嗇代碼。
            3? Exception類。如果你所依賴的庫沒有提供該類,那么在你的項目中自己寫一個,因為一般說來,std::exception并沒有提供你想要的東西。不要討論Exception所帶來的開銷,這里是C++,而異常所帶來的手感,勝過返回值10倍,而邏輯上也清晰得多。
            4? 雜七雜八的東西都放到類初始化成員列表里不是什么好事。初始化成員列表是講究順序性的,可是類在實現的時候成員變量是一個逐步添加的過程,東西多了,就會亂了,初始化列表里的順序也就對不上了。
            一般來說,只有那種需要拷貝構造函數初始化的變量,才放到初始化列表里。
            5? 成員變量的初始值賦值。成員變量很多的話,如何在它們初始化的時候傳遞變量呢?構造函數是初始化的最好選擇。但是,一個擁有十幾個參數的構造函數嗎?又或者在類完成構造之后,通過set函數來設置?由此帶來的接口龐大,還有修改失控問題卻不能忽視。
            在構造函數中傳遞一個文件名吧,然后該類負責從文件中讀取各個成員變量的初始值。我是比較傾向于這個方式的,其實類內很多變量都是規則性變量,通過從外部流中讀取,那么只要編譯一次,就可以得到不同的結果了,何樂而不為呢。
            6? 盡量不使用protected。這里是說一個類層次設計的,作為基類,可以理解為子類的抽象,不過更多的時候,這種抽象對于我來說只是一個概念的問題,毫無意義。設計基類的真正原因,是接口通用,還有代碼復用,這在我看過的某些代碼里面都是如此的,抽象的意義讓人覺得很困惑,但是一想到是代碼復用,也就霍然開朗。
            基類用public給出接口,用private給出變量,也許你會問,如果子類要用這些變量怎么辦?那么好吧,先說protected后會怎么樣吧。基類的成員變量的使用權遺留給了子類,可惜我并不喜歡那些基類的成員變量,為什么?因為在我的經驗中,基類遺留下的變量都是相當龐大的,甚至有好幾個層次的基類,那些變量,經歷了一段時間之后,你還能對他們的名稱和意義爛熟于心嗎?我反正是糊涂的,反而在子類添加的變量最明白不過。
            那么如果一定要用基類的變量怎么辦?你用那個變量只不過要實現某些功能,那么把那個功能的實現做在基類的一個函數就好了,函數總比變量來的明白。
            事實上,我并不能很肯定本條規則,因為有的變量真的是不把使用權遺留下去是不行的啊。不過盡量少用protected是沒錯的吧。
            7? 盡量少在一個封閉的函數內成對的進行動態內存分配和釋放,這種情況往往是想要一個不定長的臨時變量,如果可以,就用一個盡量長的buffer更好,否則你就要添加異常情況下刪除該變量的代碼。
            我盡可能的只在構造函數和析構函數中應付動態內存。
            8? 代碼越來越多,你能漸漸嗅出代碼冗余的味道了,重構吧,我常常是邊寫邊重構,而不是等所有東西都完成后才這樣做,因為那樣要改更多。
            posted on 2006-05-31 19:59 LOGOS 閱讀(1377) 評論(5)  編輯 收藏 引用

            FeedBack:
            # re: 編程感悟 2006-05-31 23:27 漂舟
            更貼近我們這層次程序員的經驗之談,
            贊賞作者與眾分享經驗的精神  回復  更多評論
              
            # re: 編程感悟 2006-06-02 00:54 erran
            希望cppblog上多一些這樣的文章~~~  回復  更多評論
              
            # re: 編程感悟 2006-06-09 09:28 任我行
            很好,希望以后能多多寫這樣的好文章。  回復  更多評論
              
            # re: 編程感悟 2006-06-30 15:32 Arcrest
            1,關鍵是抽象吧,設計的難點
            2,偶也感覺很頭疼的,找不到一個合適的log庫,log4cxx等都有好多無法容忍的缺點,自己改寫小點吧,又好累~~
            3和4,呵呵,Effective C++里面討論得不少
            5,使用文件這種方法很局限,缺點太多,最重要的等于是給這個類強加了一個讀取文件的依賴。如果參數太長,應該考慮重構,用類來替代,至于類實例的初始化,從文件讀取還是從網絡讀取,那是新的類的職責了

            6,所有變量private,部分變量可以在提供protected或者public的accessor方法

            7,很多函數都會需要創建新堆對象,用std::auto_ptr或者boost::shared_ptr吧  回復  更多評論
              
            # re: 編程感悟 2006-06-30 19:26 LOGOS
            Arcrest領悟很深啊。^_^
            我會去你的blog逛逛的,你可要寫些好東西啊  回復  更多評論
              
            久久久精品久久久久久| 亚洲伊人久久综合影院| 久久精品国产91久久麻豆自制| 国产精品青草久久久久婷婷 | 久久精品午夜一区二区福利 | 亚洲中文字幕无码久久2017| 无码伊人66久久大杳蕉网站谷歌 | 青青草国产97免久久费观看| 一级做a爰片久久毛片免费陪 | 久久精品亚洲福利| 一个色综合久久| 欧美牲交A欧牲交aⅴ久久| 国产精品99久久精品| 久久精品国产精品亚洲下载| 99久久综合国产精品免费| 久久亚洲欧美国产精品| 777久久精品一区二区三区无码| 久久久久九九精品影院| 久久久亚洲AV波多野结衣| 91精品国产91久久综合| 久久精品国产99久久久香蕉| 欧美精品国产综合久久| 777米奇久久最新地址| 久久青青草原精品国产不卡| 亚洲女久久久噜噜噜熟女| 欧美综合天天夜夜久久| 97视频久久久| 香港aa三级久久三级| 久久久亚洲AV波多野结衣| 夜夜亚洲天天久久| 波多野结衣AV无码久久一区| 久久这里只精品国产99热| 国产精品久久久久久久久久影院| 国产精品久久久久久久久鸭 | 伊人 久久 精品| 国产91久久精品一区二区| 伊人精品久久久久7777| 亚洲国产精品久久| 亚洲AV无码成人网站久久精品大| 久久www免费人成看国产片 | 亚洲国产综合久久天堂 |