• <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>

            luke

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              3 隨筆 :: 0 文章 :: 0 評論 :: 0 Trackbacks

            2009年4月1日 #

            以前一直沒有關心std::endl的工作機制,最近突然想一窺究竟,于是下載了sgi的stl(http://www.sgi.com/tech/stl/)實現,
            于是恍然大悟,對其實現者真是敬佩。

            在文件Ostream中class basic_ostream 有如下成員函數:

             basic_ostream& operator<< (basic_ostream& (*__f)(basic_ostream&))
                { return __f(*this); }

             basic_ostream& operator<< (_Basic_ios& (*__f)(_Basic_ios&))
                { __f(*this); return *this; }

             basic_ostream& operator<< (ios_base& (*__f)(ios_base&))
                { __f(*this); return *this; }

            然后有如下全局函數:
            template <class _CharT, class _Traits>
            inline basic_ostream<_CharT, _Traits>&
            endl(basic_ostream<_CharT, _Traits>& __os) {
              __os.put(__os.widen('\n'));
              __os.flush();
              return __os;
            }

            可見原來我們經常使用的cout<<.....<<endl中的endl竟然是一個函數指針,由此我們還可以找到如下定義:

            // basefield manipulators, section 27.4.5.3
            inline ios_base& dec(ios_base& __s)
              { __s.setf(ios_base::dec, ios_base::basefield); return __s; }

            inline ios_base& hex(ios_base& __s)
              { __s.setf(ios_base::hex, ios_base::basefield); return __s; }

            inline ios_base& oct(ios_base& __s)
              { __s.setf(ios_base::oct, ios_base::basefield); return __s; }

            原來這些我們經常見到的C++流輸出格式符居然都是一些函數,都是通過重載<<操作符來實現的。

            posted @ 2009-04-01 15:15 盧克 閱讀(859) | 評論 (0)編輯 收藏

            2009年3月13日 #

            今日粗看boost的代碼,發現很多類都繼承noncopyable,以下是noncopyable的代碼:
            class noncopyable
              {
               protected:
                  noncopyable() {}
                  ~noncopyable() {}
               private:  // emphasize the following members are private
                  noncopyable( const noncopyable& );
                  const noncopyable& operator=( const noncopyable& );
              };

            這里的設計思想是讓子類繼承,但是阻止子類調用賦值和copy構造函數,有什么用呢?
            寫代碼的時候我經常喜歡用singleton模式,比如那些工廠類,管理者類之類的,但是寫這些
            singleton的時候當然是希望全局只有一個,而且不希望別人在用的時候又自己創造一個,往往
            就要每寫一個singleton類就要在類的declaration中把它們的構造函數,賦值函數,析構函數,copy構造函數隱藏到
            private或者protected之中,這樣真的很累。
              現在好了,只要讓這些singleton直接繼承noncopyable就ok了。這樣至少可以不用多寫賦值和copy構造
            函數了;構造和析構函數看情況而定了。

            class noncopyable的基本思想是把構造函數和析構函數設置protected權限,這樣子類可以調用,但是外面的類不能調用,
            那么當子類需要定義構造函數的時候不至于通不過編譯。但是最關鍵的是noncopyable把copy構造函數和copy賦值函數做成了
            private,這就意味著除非子類定義自己的copy構造和賦值函數,否則在子類沒有定義的情況下,外面的調用者是不能夠通過
            賦值和copy構造等手段來產生一個新的子類對象的。舉個簡單的例子:
            class Test : public noncopyable
            {
            };

            void main()
            {
               Test a,c;
               Test b(a);  ///<------(1) error

               c = a;     ///<------(2) error
            }

            如果Test類沒有繼承 noncopyable,那么(1)和(2)都可以通過編譯,但是一旦Test繼承了noncopyable,則(1)和(2)都通不過
            編譯,從而可以防止調用者寫一些錯誤的代碼,這不正是我們做singleton對象所需要的嗎?



            posted @ 2009-03-13 11:00 盧克 閱讀(6260) | 評論 (0)編輯 收藏

            2008年10月13日 #

              我的service程序在windows XP 和 windows2003下工作正常。但是在vista和windows2008下安裝的時候總是在啟動service這一步的時候失敗。一直沒有找到原因。這兩天集中精力,終于找到了原因,但是卻解決不了這個問題。
              做了如下幾個測試:
              (1)把ServiceMain開始部分做成一個console程序,運行OK,這說明主要部分代碼邏輯沒有問題。
              (2)去掉ServiceMain()中的大部分功能代碼,做一個簡單的service,運行OK,這說明原來的service安裝和啟動部分代碼也沒有問題。
              (3)分步排除各個dll。
              最后發現導致無法啟動的罪魁禍首居然是libmysql.dll,我如果在程序中屏蔽掉所有mysql的調用,等于程序啟動的時候不加載libmysql.dll,那么就可以順利啟動,接著更換到最新的libmysql.dll(版本5.0.67),仍然是啟動不成功;后來切換到一個同事的老版本libmysql.dll,居然可以啟動成功。5.0.67版本libmysql.dll (opt)的大小是2M多,而我同事的那個libmysql.dll才1M多,難道他的版本是mysql4.x ?
              究竟是什么原因導致這個問題的?


            posted @ 2008-10-13 17:06 盧克 閱讀(246) | 評論 (0)編輯 收藏

            僅列出標題  
            欧美色综合久久久久久| 狼狼综合久久久久综合网| 久久精品无码一区二区三区| 色婷婷综合久久久中文字幕| 精品久久久久久中文字幕大豆网| 国内精品久久久久久久久电影网 | 久久99国产精品久久99果冻传媒| 亚洲综合精品香蕉久久网97| 久久九色综合九色99伊人| 一本色道久久综合狠狠躁| 久久精品九九亚洲精品| 亚洲国产小视频精品久久久三级 | 久久久久久久久无码精品亚洲日韩 | 久久99国产精品久久99果冻传媒| 久久人人爽人人爽AV片| 久久国产精品99国产精| 国产精品丝袜久久久久久不卡 | 久久超碰97人人做人人爱| 中文精品久久久久国产网址 | 免费无码国产欧美久久18| 成人资源影音先锋久久资源网| 久久久精品视频免费观看| 97久久久久人妻精品专区| 久久大香萑太香蕉av| 久久se这里只有精品| 国产精品一区二区久久不卡| 亚洲一级Av无码毛片久久精品| 99久久精品国产一区二区三区 | 久久亚洲中文字幕精品一区四| 久久99国产精品久久99果冻传媒| 新狼窝色AV性久久久久久| 香港aa三级久久三级老师2021国产三级精品三级在 | 国产亚洲美女精品久久久久狼| 久久中文字幕人妻熟av女| 久久无码一区二区三区少妇| 久久九色综合九色99伊人| 久久国产精品免费一区| 久久久精品日本一区二区三区| 91精品国产91久久| 国产精品久久久久久久午夜片| 天天爽天天爽天天片a久久网|