• <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>
            franksunny的個人技術空間
            獲得人生中的成功需要的專注與堅持不懈多過天才與機會。 ——C.W. Wendte

            網(wǎng)訊筆試歸來

            昨天去網(wǎng)訊(杭州)筆試了,做了下筆試題,感覺題目都不難,但是自己做的的確不怎么樣,估計是沒機會去了,不過暫時還是先把幾道自己還記得的題目,寫出來,總結(jié)下,以做復習。

            1、  要求自己實現(xiàn) String 類,給出了 String 類的以下頭文件類聲明

            class String

            {

            public:

                   String(const char *m_char = NULL);

                   String(const String & Str);

                   String& operator = (const String &Str);

                   ~String();

            private:

                   char * m_Data;

            };

             

            關于 String 類的筆試題,以前看林銳的隨筆時聽說他在微軟面試時曾碰到那么一道題目,我自己也沒有真的下筆去做過,平常都是拿來就用的,這次自己碰到,才知道會死得那么慘,反正編得不堪入目(我就不拿出來獻丑了),下面是我回來后,自己重新寫的答案。

            String::String(const char* m_char)

            {

                   int m_nLength = strlen(m_char) + 1;

                   if (m_Data != NULL)

                   {

                          delete [] m_Data;

                          m_Data = NULL;

                   }// 以上判斷是否必要 ??

                   m_Data = new char[m_nLength];

                   memcpy(m_Data, m_char, m_nLength);

            }

             

            String::String(const String &Str)

            {

                   int m_nLength = strlen(Str.m_Data) + 1;// 以前真的不知道,原來對象的私有變量

            // 在類的實現(xiàn)代碼中也是可以訪問的

                   if (m_Data != NULL)

                   {

                          delete [] m_Data;

                          m_Data = NULL;

                   }// 以上判斷是否必要 ??

                   m_Data = new char[m_nLength];

                   memcpy(m_Data, Str.m_Data, m_nLength);

            }

             

            String& String::operator = (const String& Str) 

            {

                   if(this == &Str)

                          return *this;

             

                   int m_nLength = strlen(Str.m_Data) + 1;

                   if (m_Data != NULL)

                   {

                          delete [] m_Data;

                          m_Data = NULL;

                   }// 以上判斷是否必要 ??

                  

                   m_Data = new char[m_nLength];

                   memcpy(m_Data, Str.m_Data, m_nLength);

                   return *this;

            }

             

            String::~String()

            {

                   if (m_Data != NULL)

                   {

                          delete [] m_Data;

                          m_Data = NULL;

                   }

            }

             

            2、  關于內(nèi)存分配

            這個題目很簡單,就給了一個函數(shù),然后問函數(shù)內(nèi)的局部變量存放在哪里,我也不知道為什么當時會選擇 heap( ) ,下面再把幾個概念羅列出來:

            1.            堆區(qū)( heap ):由程序員申請分配和釋放,屬動態(tài)內(nèi)存分配方式,若程序員不釋放,程序結(jié)束時可能會由 OS 回收。不過這個內(nèi)存分配很容易引起問題,如果申請的內(nèi)存不釋放就會造成內(nèi)存泄漏;如果釋放的不是所要釋放的內(nèi)存,則輕者引起程序運行結(jié)果出錯,重者系統(tǒng)崩潰。

            2.            棧區(qū)( stack ):編譯器自動分配釋放,存放函數(shù)的形參值、局部變量的值,也是屬于動態(tài)內(nèi)存分配方式,它由系統(tǒng)分配,所以執(zhí)行效率也高,不過自由度小,聲明時就得決定其具體大小。

            3.            全局區(qū)(靜態(tài)區(qū))( static ):全局變量和靜態(tài)變量的存儲是放在一塊的,而且初始化的全局變量和靜態(tài)變量在一塊區(qū)域,未初始化的全局變量和未初始化的靜態(tài)變量在相鄰的另一塊區(qū)域。程序結(jié)束后由系統(tǒng)釋放,所以也不會造成內(nèi)存問題。

            除了以上的變量外,還有兩類存放位置,文字常量區(qū)和程序代碼區(qū),兩者都是由系統(tǒng)分配和釋放,且文字常量區(qū)和前面三區(qū)合成為程序數(shù)據(jù)區(qū),與程序代碼區(qū)相對應。

            3、  關于類繼承的構(gòu)造和析構(gòu)函數(shù)

            class Base

            {

            public:

                   Base(){cout<< "Base" <<endl;};

                   ~Base(){cout<<"~Base"<<endl;};

            protected:

            private:

            };

             

            class First:public Base

            {

            public:

                   First(){cout << "First" << endl;};

                   ~First(){cout << "~First" <<endl;};

            };

             

            int main()

            {

                   Base *a = new First;

                   delete a;

            }

            問程序的輸出會是什么?

            結(jié)果很簡單,也就是 Base

                                           First

                               ~Base

            其它還有一個關于 & 的題目,把我搞的云里霧里的,還要再看些東西才知道怎么來解釋。

            posted on 2007-03-04 21:53 frank.sunny 閱讀(3379) 評論(10)  編輯 收藏 引用 所屬分類: C/C++學習和實踐

            FeedBack:
            # re: 網(wǎng)訊筆試歸來
            2007-03-04 23:01 | 郁郁寡歡
            第一,你的背景色太要命了,你自己看一分鐘試試!
            第二,
            ===================
            if (m_Data != NULL)
            {
            delete [] m_Data;
            m_Data = NULL;

            }
            ====================
            你同樣的代碼重復次數(shù)太多了,就不能做成一個函數(shù)嗎?

            第三,每次delete然后new,也可以做一些判斷,不用delete直接strcpy吧,不過這屬于優(yōu)化了,對于筆試應該影響不大吧?  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-04 23:09 | SmartPtr
            if (m_Data != NULL)
            {
            delete [] m_Data;
            m_Data = NULL;
            }

            ***************************************
            因為C++delete一個NULL指針是合法的。(可能編譯器delete的時候就對NULL進行了特殊處理),所以無需判斷,直接寫:
            delete [] m_Data;
            m_Data = NULL;   回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-04 23:19 | DC
            前面2個Constructor,肯定是不需要
            if (m_Data != NULL)
            {
            delete [] m_Data;
            m_Data = NULL;
            }
            而且是應該直接付值m_Data = NULL;先,否則,程序在這里會有異常!因為m_Data的初值不會為0。


            后面的String& String::operator = (const String& Str)需要判斷m_Data != NULL以判斷是否需要釋放內(nèi)存。


            你現(xiàn)在的答案還是蠻多漏洞。  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 17:01 | frank.sunny
            謝謝如上各位指點,我以后用代碼時背景改成灰色好了。

            根據(jù)大家的建議,我后來改了下代碼,改成如下方式:
            String::String(const char* m_char) :m_Data(NULL)
            {
            int m_nLength = strlen(m_char) + 1;
            m_Data = new char[m_nLength];
            strcpy(m_Data, m_char);
            }

            String::String(const String &Str) : m_Data(NULL)
            {
            int m_nLength = strlen(Str.m_Data) + 1;
            m_Data = new char[m_nLength];
            strcpy(m_Data, Str.m_Data);
            }
            個人還參考了下memcpy和strcpy的區(qū)別,也沒說哪個執(zhí)行效率高些,當然能簡化就簡化,  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 19:00 | tx7do
            memcpy是匯編實現(xiàn)的,效率還是很高的。  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 21:40 | badtiger
            長見識了!謝謝各位  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 22:27 | frank.sunny
            @tx7do

            的確如你所說,我也長見識了,呵呵
            謝謝你
              回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-08 17:33 | ZHua
            一同學習阿 呵呵  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2008-10-14 18:17 | 貓貓咬
            這樣實現(xiàn)String類太低效了,應該一下分配出一定的空間(大于初始化的字符串長度),4字節(jié)的倍數(shù)會更好些。  回復  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2008-10-14 18:25 | 萬連文
            這種問題,我的答案是 copy mfc的CString,ok?  回復  更多評論
              

            常用鏈接

            留言簿(13)

            隨筆分類

            個人其它博客

            基礎知識鏈接

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品永久久久久久久久久| 久久亚洲精品无码AV红樱桃| 亚洲国产精品18久久久久久| 理论片午午伦夜理片久久| 99久久国产综合精品网成人影院| 久久亚洲精品成人av无码网站 | 一本色道久久88综合日韩精品| 品成人欧美大片久久国产欧美| 久久中文娱乐网| 国产精品九九久久免费视频 | 狠狠色综合久久久久尤物| 欧美综合天天夜夜久久| 99久久国产综合精品网成人影院| 国产精品日韩欧美久久综合| 久久综合成人网| 国产精品成人久久久| 影音先锋女人AV鲁色资源网久久 | 99久久国产宗和精品1上映| 午夜久久久久久禁播电影| 久久精品99久久香蕉国产色戒 | 亚洲伊人久久精品影院| 人妻无码αv中文字幕久久| 蜜桃麻豆www久久| 一97日本道伊人久久综合影院| 久久久久久免费视频| 久久国产精品成人影院| 国产99久久久国产精品~~牛| 欧美激情精品久久久久久久九九九 | 精品久久久久久无码中文字幕一区| 久久久久亚洲AV无码永不| 国产亚洲精久久久久久无码AV| 亚洲午夜无码久久久久小说| 久久久女人与动物群交毛片| 久久免费大片| 久久久精品人妻一区二区三区四| 国产激情久久久久影院小草 | 色综合久久综合网观看| 久久综合久久美利坚合众国| 一级做a爰片久久毛片人呢| 欧美伊人久久大香线蕉综合| 91精品国产色综久久|