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

            亚洲AV无码1区2区久久| 一本一道久久a久久精品综合| 久久狠狠爱亚洲综合影院| 久久免费看黄a级毛片| 久久er99热精品一区二区| 久久精品无码一区二区日韩AV| 少妇被又大又粗又爽毛片久久黑人 | 久久国产欧美日韩精品| 久久免费精品一区二区| 久久久精品国产| 99久久精品无码一区二区毛片 | 中文精品久久久久国产网址| 狠狠色综合久久久久尤物| 老色鬼久久亚洲AV综合| 亚洲国产成人精品无码久久久久久综合 | 国产精自产拍久久久久久蜜| 人妻少妇久久中文字幕| 日本精品久久久久影院日本| 久久99精品国产99久久6男男| 2019久久久高清456| 久久国产精品偷99| 69久久精品无码一区二区| 亚洲一区精品伊人久久伊人 | 99久久国产综合精品女同图片| 94久久国产乱子伦精品免费| 久久免费的精品国产V∧| 国产精品久久久久久五月尺| 久久精品国产亚洲av瑜伽| 久久综合狠狠色综合伊人| 国产精品一久久香蕉国产线看观看| 久久久久综合中文字幕| 精品久久久久久国产三级| 国产99久久九九精品无码| 久久电影网2021| 久久最近最新中文字幕大全| 精品999久久久久久中文字幕| 久久无码人妻一区二区三区| 久久亚洲精品成人AV| 久久久久国产精品熟女影院| 久久超乳爆乳中文字幕| 精品久久香蕉国产线看观看亚洲|