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

            旅途

            如果想飛得高,就該把地平線忘掉

            CC++筆試經(jīng)典題目2

            7. 以下反向遍歷array數(shù)組的方法有什么錯(cuò)誤?
            vector array;
            array.push_back( 1 );
            array.push_back( 2 );
            array.push_back( 3 );
            for( vector::size_type i=array.size()-1; i>=0; --i ) // 反向遍歷array數(shù)組
            {
            cout << array[i] << endl;
            }

            答:首先數(shù)組定義有誤,應(yīng)加上類型參數(shù):vector<int> array。其次vector::size_type被定義為unsigned int,即無(wú)符號(hào)數(shù),這樣做為循環(huán)變量的i為0時(shí)再減1就會(huì)變成最大的整數(shù),導(dǎo)致循環(huán)失去控制。


            8. 以下代碼中的輸出語(yǔ)句輸出0嗎,為什么?
            struct CLS
            {
            int m_i;
            CLS( int i ) : m_i(i) {}
            CLS()
            {
            CLS(0);
            }
            };
            CLS obj;
            cout << obj.m_i << endl;

            答:不能。在默認(rèn)構(gòu)造函數(shù)內(nèi)部再調(diào)用帶參的構(gòu)造函數(shù)屬用戶行為而非編譯器行為,亦即僅執(zhí)行函數(shù)調(diào)用,而不會(huì)執(zhí)行其后的初始化表達(dá)式。只有在生成對(duì)象時(shí),初始化表達(dá)式才會(huì)隨相應(yīng)的構(gòu)造函數(shù)一起調(diào)用。


            9. C++中的空類,默認(rèn)產(chǎn)生哪些類成員函數(shù)?
            答:
            class Empty
            {
            public:
            Empty(); // 缺省構(gòu)造函數(shù)
            Empty( const Empty& ); // 拷貝構(gòu)造函數(shù)
            ~Empty(); // 析構(gòu)函數(shù)
            Empty& operator=( const Empty& ); // 賦值運(yùn)算符
            Empty* operator&(); // 取址運(yùn)算符
            const Empty* operator&() const; // 取址運(yùn)算符 const
            };

            ?

            10. 以下兩條輸出語(yǔ)句分別輸出什么?
            float a = 1.0f;
            cout << (int)a << endl;
            cout << (int&)a << endl;
            cout << boolalpha << ( (int)a == (int&)a ) << endl; // 輸出什么?
            float b = 0.0f;
            cout << (int)b << endl;
            cout << (int&)b << endl;
            cout << boolalpha << ( (int)b == (int&)b ) << endl; // 輸出什么?

            答:分別輸出false和true。注意轉(zhuǎn)換的應(yīng)用。(int)a實(shí)際上是以浮點(diǎn)數(shù)a為參數(shù)構(gòu)造了一個(gè)整型數(shù),該整數(shù)的值是1,(int&)a則是告訴編譯器將a當(dāng)作整數(shù)看(并沒有做任何實(shí)質(zhì)上的轉(zhuǎn)換)。因?yàn)?以整數(shù)形式存放和以浮點(diǎn)形式存放其內(nèi)存數(shù)據(jù)是不一樣的,因此兩者不等。對(duì)b的兩種轉(zhuǎn)換意義同上,但是0的整數(shù)形式和浮點(diǎn)形式其內(nèi)存數(shù)據(jù)是一樣的,因此在這種特殊情形下,兩者相等(僅僅在數(shù)值意義上)。
            注意,程序的輸出會(huì)顯示(int&)a=1065353216,這個(gè)值是怎么來的呢?前面已經(jīng)說了,1以浮點(diǎn)數(shù)形式存放在內(nèi)存中,按ieee754規(guī)定,其內(nèi)容為0x0000803F(已考慮字節(jié)反序)。這也就是a這個(gè)變量所占據(jù)的內(nèi)存單元的值。當(dāng)(int&)a出現(xiàn)時(shí),它相當(dāng)于告訴它的上下文:“把這塊地址當(dāng)做整數(shù)看待!不要管它原來是什么。”這樣,內(nèi)容0x0000803F按整數(shù)解釋,其值正好就是1065353216(十進(jìn)制數(shù))。
            通過查看匯編代碼可以證實(shí)“(int)a相當(dāng)于重新構(gòu)造了一個(gè)值等于a的整型數(shù)”之說,而(int&)的作用則僅僅是表達(dá)了一個(gè)類型信息,意義在于為cout<<及==選擇正確的重載版本。


            11. 以下代碼有什么問題?
            typedef vector IntArray;
            IntArray array;
            array.push_back( 1 );
            array.push_back( 2 );
            array.push_back( 2 );
            array.push_back( 3 );
            // 刪除array數(shù)組中所有的2
            for( IntArray::iterator itor=array.begin(); itor!=array.end(); ++itor )
            {
            if( 2 == *itor ) array.erase( itor );
            }

            答:同樣有缺少類型參數(shù)的問題。另外,每次調(diào)用“array.erase( itor );”,被刪除元素之后的內(nèi)容會(huì)自動(dòng)往前移,導(dǎo)致迭代漏項(xiàng),應(yīng)在刪除一項(xiàng)后使itor--,使之從已經(jīng)前移的下一個(gè)元素起繼續(xù)遍歷。

            12. 寫一個(gè)函數(shù),完成內(nèi)存之間的拷貝。[考慮問題是否全面]
            答:
            void* mymemcpy( void *dest, const void *src, size_t count )
            {
            char* pdest = static_cast<char*>( dest );
            const char* psrc = static_cast<const char*>( src );
            if( pdest>psrc && pdest<psrc+cout ) 能考慮到這種情況就行了
            {
            for( size_t i=count-1; i!=-1; --i )
            pdest[i] = psrc[i];
            }
            else
            {
            for( size_t i=0; i<count; ++i )
            pdest[i] = psrc[i];
            }
            return dest;
            }

            ?

            posted on 2007-09-04 00:52 旅途 閱讀(529) 評(píng)論(2)  編輯 收藏 引用 所屬分類: C/C++

            Feedback

            # re: CC++筆試經(jīng)典題目2 2009-01-30 17:04 http://www.ok2002.com/

            //C++ 空類默認(rèn)產(chǎn)生的類成員函數(shù):缺省構(gòu)造函數(shù),拷貝構(gòu)造函數(shù),析構(gòu)函數(shù),賦值運(yùn)算符,取址運(yùn)算符,取址運(yùn)算符 const

            #include<iostream>
            using namespace std;

            class class1
            {
            public:
            class1(){}//缺省構(gòu)造函數(shù)
            class1(const class1&){}//拷貝構(gòu)造函數(shù)
            ~class1(){}//析構(gòu)函數(shù)
            class1&operator=(const class1&){}//賦值運(yùn)算符
            class1*operator&(){}//取址運(yùn)算符
            const class1*operator&()const{}//取址運(yùn)算符 const
            };

            //空類class2會(huì)產(chǎn)生class1一樣的成員函數(shù)
            class class2
            {
            };

            void main()
            {
            class2 obj1;//缺省構(gòu)造函數(shù)
            class2 obj2;

            obj1=obj2;//賦值運(yùn)算符

            &obj2;//取址運(yùn)算符

            class2 obj3(obj1);//拷貝構(gòu)造函數(shù)

            class2 const obj4;
            &obj4;//取址運(yùn)算符 const
            }
              回復(fù)  更多評(píng)論   

            # erase刪除元素后返回被刪除元素的下一個(gè)iterator 2009-01-30 17:34 http://www.ok2002.com/

            #include<vector>
            #include<iostream>
            using namespace std;

            //來源:http://www.ok2002.com/

            void display(vector<int>v)
            {
            vector<int>::iterator u;
            for(u=v.begin();u!=v.end();++u)
            cout<<*u<<" ";
            cout<<endl;
            }

            void main()
            {
            vector<int>v;
            int i;
            for(i=0;i<10;i++)
            v.push_back(i);

            display(v);

            vector<int>::iterator u;
            for(u=v.begin();u!=v.end();++u)
            {
            if(3==*u)
            {
            u=v.erase(u);//erase刪除元素后返回被刪除元素的下一個(gè)iterator
            cout<<*u<<endl;//輸出4
            }
            }

            display(v);
            }

            /*--
            0 1 2 3 4 5 6 7 8 9
            4
            0 1 2 4 5 6 7 8 9
            Press any key to continue
            --*/  回復(fù)  更多評(píng)論   

            色婷婷狠狠久久综合五月| 国产香蕉97碰碰久久人人| 久久免费国产精品| 国产午夜精品久久久久九九| 久久激情亚洲精品无码?V| 精品伊人久久久| 国产亚洲精品美女久久久| 中文字幕久久欲求不满| 欧美大战日韩91综合一区婷婷久久青草| 欧美久久综合九色综合| 中文字幕亚洲综合久久| 色欲久久久天天天综合网精品| 久久亚洲精品无码aⅴ大香| 天天久久狠狠色综合| 久久精品国产精品亚洲下载| 久久婷婷五月综合97色一本一本| 久久国产精品无码HDAV| 久久国产福利免费| 久久人妻少妇嫩草AV无码专区| 丁香五月网久久综合| 日韩电影久久久被窝网| 精品综合久久久久久97超人 | 嫩草影院久久国产精品| 中文字幕无码久久精品青草| 色噜噜狠狠先锋影音久久| 无码精品久久久久久人妻中字| 四虎久久影院| 欧洲国产伦久久久久久久| 久久精品草草草| 久久精品国产第一区二区三区| 久久只这里是精品66| 日本亚洲色大成网站WWW久久| 91精品国产高清久久久久久91| 国产精品久久久久久吹潮| 久久人爽人人爽人人片AV| 久久人人爽人人人人片av| 亚洲国产日韩综合久久精品| 日本加勒比久久精品| 天堂无码久久综合东京热| 理论片午午伦夜理片久久| 精品久久久久久久久免费影院|