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

            2009年12月21日

            條款2:盡量以CONST,ENUM,INLINE替換#DEFINE

            類中定義常量:static const int numturns = 5;

            這是聲明式而非定義式。若不需取它們的地址,無須提供定義式。定義式如下:

            const int GamePlayer::NumTurns;



            一個class需要常量值,定義如下:

            enum{NumTurns = 5};

            int scores[NumTurns];



            關(guān)于“形似函數(shù)的宏,最好改用inline函數(shù)替換#defines”

            但,經(jīng)驗證明。宏的速度要比用inline的方法快。

            在一些對速度要求非常嚴格的項目中,這個方面還是要有所取舍的。

            posted @ 2009-12-21 00:18 蜜蜂 閱讀(233) | 評論 (1)編輯 收藏

            vector

            #include <vector>
            #include 
            <string>
            #include 
            <algorithm>
            #include 
            <iterator>
            #include 
            <iostream.h>
            // #include <iostream>

            class GreaterThan {
            public:
                GreaterThan( 
            int size = 6 ) : _size( size ){}
                
            int size() { return _size; }

                
            bool operator()(const string & s1) {
                    
            return s1.size() > 6;
                    }

            private:
                
            int _size;
            };

            template 
            <class Type>
            class PrintElem {
            public:
                
            void operator()( const Type &elem ) 
                {
                    
            ++_cnt;
                    
            if ( _cnt % 8 == 0 ) { cout << endl; }
                    cout 
            << elem << " ";
                }
                
            private:
                
            static int _cnt;
            };

            template 
            < class Type >
                   
            int PrintElem<Type>::_cnt = 0;

            class LessThan {
            public:
                
            bool operator()(const string & s1, const string & s2 ) {
                     
            return s1.size() < s2.size();
                    }
            };

            typedef vector
            <string, allocator> textwords;

            void process_vocab( vector<textwords, allocator> *pvec )
            {
                
            if ( ! pvec ) 
                     
            // issue warning message
                     return;

                vector
            < string, allocator > texts; 

                vector
            <textwords, allocator>::iterator iter = pvec->begin();
                
            for ( ; iter != pvec->end(); ++iter )
                          copy( (
            *iter).begin(), (*iter).end(), back_inserter( texts ));

                
            // sort the elements of texts
                sort( texts.begin(), texts.end() );
                for_each( texts.begin(), texts.end(), PrintElem
            <string>() );

                cout 
            << endl << endl;

                
            // delete all duplicate elements 
                vector<string, allocator>::iterator it;
                it 
            = unique( texts.begin(), texts.end() );
                texts.erase( it, texts.end() );
                for_each( texts.begin(), texts.end(), PrintElem
            <string>() );

                cout 
            << endl << endl;

                stable_sort( texts.begin(), texts.end(), LessThan() );
                for_each( texts.begin(), texts.end(), PrintElem
            <string>() );

                cout 
            << endl << endl;

                
            // count number of strings greater than length 6
                int cnt = 0;

                
            // obsolete form of count -- standard changes this
                count_if( texts.begin(), texts.end(), GreaterThan(), cnt );

                cout 
            << "Number of words greater than length six are "
                         
            << cnt << endl;

                
            // 

                
            static string rw[] = { "and""if""or""but""the" };
                vector
            <string,allocator> remove_words( rw, rw+5 );

                vector
            <string, allocator>::iterator it2 = remove_words.begin();
                
            for ( ; it2 != remove_words.end(); ++it2 ) {
                    
            int cnt = 0;
                    
            // obsolete form of count -- standard changes this
                        count( texts.begin(), texts.end(), *it2, cnt );
                
                    cout 
            << cnt << " instances removed:  " 
                             
            << (*it2) << endl;
                
                        texts.erase(
                            remove(texts.begin(),texts.end(),
            *it2),
                            texts.end()
                       );
                   }

                cout 
            << endl << endl;
                for_each( texts.begin(), texts.end(), PrintElem
            <string>() );
            }

            typedef vector
            <string,allocator>::difference_type diff_type;
            #include 
            <fstream.h>

            main()
            {
                 vector
            <textwords, allocator> sample;
                 vector
            <string,allocator>       t1, t2; 
                 
            string               t1fn, t2fn;

                 cout 
            << "text file #1: "; cin >> t1fn;
                 cout 
            << "text file #2: "; cin >> t2fn;

                 ifstream infile1( t1fn.c_str());
                 ifstream infile2( t2fn.c_str());

                 istream_iterator
            < string, diff_type > input_set1( infile1 ), eos; 
                 istream_iterator
            < string, diff_type > input_set2( infile2 );

                 copy( input_set1, eos, back_inserter( t1 ));
                 copy( input_set2, eos, back_inserter( t2 ));

                 sample.push_back( t1 ); sample.push_back( t2 );
                 process_vocab( 
            &sample );
            }

            posted @ 2009-12-21 00:14 蜜蜂 閱讀(206) | 評論 (0)編輯 收藏

            僅列出標題  
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产综合久久久久久鬼色| a级毛片无码兔费真人久久| 国产精品青草久久久久福利99| 99久久无色码中文字幕人妻| 久久亚洲色一区二区三区| 国产精品日韩深夜福利久久| 久久96国产精品久久久| 国产Av激情久久无码天堂| 久久久久99精品成人片欧美 | 精品久久久噜噜噜久久久 | 99久久国产免费福利| 国产精品一久久香蕉产线看| 久久精品无码专区免费青青| 亚洲国产精品无码久久SM| 日韩精品久久无码人妻中文字幕 | 国产99久久精品一区二区| 99久久人妻无码精品系列蜜桃| 久久久久久久久无码精品亚洲日韩 | 久久这里只精品国产99热| 91亚洲国产成人久久精品| 久久国产精品一区| 久久综合色老色| 无码久久精品国产亚洲Av影片 | 久久91精品国产91久| 久久中文字幕人妻丝袜| 久久亚洲中文字幕精品有坂深雪| 色欲综合久久躁天天躁蜜桃| 99国产欧美精品久久久蜜芽| 亚洲国产精品一区二区久久| 精品久久人人爽天天玩人人妻| 香港aa三级久久三级老师2021国产三级精品三级在 | 99久久精品国内| 94久久国产乱子伦精品免费| 老司机午夜网站国内精品久久久久久久久| 人妻无码久久精品| 久久大香香蕉国产| 99久久精品国产一区二区| 婷婷久久综合| 狠狠色丁香久久婷婷综合五月| 91精品免费久久久久久久久| 一日本道伊人久久综合影|