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

            網(wǎng)訊筆試歸來

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

            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;

            };

             

            關(guān)于 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、  關(guān)于內(nèi)存分配

            這個題目很簡單,就給了一個函數(shù),然后問函數(shù)內(nèi)的局部變量存放在哪里,我也不知道為什么當(dāng)時會選擇 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ū)相對應(yīng)。

            3、  關(guān)于類繼承的構(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

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

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

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

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

            第三,每次delete然后new,也可以做一些判斷,不用delete直接strcpy吧,不過這屬于優(yōu)化了,對于筆試應(yīng)該影響不大吧?  回復(fù)  更多評論
              
            # 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;   回復(fù)  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-04 23:19 | DC
            前面2個Constructor,肯定是不需要
            if (m_Data != NULL)
            {
            delete [] m_Data;
            m_Data = NULL;
            }
            而且是應(yīng)該直接付值m_Data = NULL;先,否則,程序在這里會有異常!因為m_Data的初值不會為0。


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


            你現(xiàn)在的答案還是蠻多漏洞。  回復(fù)  更多評論
              
            # 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í)行效率高些,當(dāng)然能簡化就簡化,  回復(fù)  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 19:00 | tx7do
            memcpy是匯編實現(xiàn)的,效率還是很高的。  回復(fù)  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 21:40 | badtiger
            長見識了!謝謝各位  回復(fù)  更多評論
              
            # re: 網(wǎng)訊筆試歸來
            2007-03-05 22:27 | frank.sunny
            @tx7do

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

            常用鏈接

            留言簿(13)

            隨筆分類

            個人其它博客

            基礎(chǔ)知識鏈接

            最新評論

            閱讀排行榜

            評論排行榜

            久久亚洲色一区二区三区| 99久久香蕉国产线看观香| 国产69精品久久久久APP下载| 国产精品久久久久aaaa| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 国产成人综合久久精品尤物| 日日噜噜夜夜狠狠久久丁香五月 | 99精品国产在热久久| 久久香蕉国产线看观看精品yw| 国内高清久久久久久| 伊人久久大香线焦AV综合影院| 精品久久亚洲中文无码| 国产aⅴ激情无码久久| 国产精品久久久久久久久软件| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 国产69精品久久久久777| 波多野结衣中文字幕久久 | 久久久久亚洲AV无码观看 | 麻豆亚洲AV永久无码精品久久| 午夜不卡久久精品无码免费| 久久久精品2019免费观看| 72种姿势欧美久久久久大黄蕉| 精品无码久久久久久尤物| 成人综合伊人五月婷久久| 国产激情久久久久影院老熟女免费 | 91亚洲国产成人久久精品网址| 日韩精品久久久久久久电影蜜臀 | 热久久视久久精品18| 久久精品国产99久久久古代| 无码日韩人妻精品久久蜜桃 | 国产精品欧美久久久天天影视| 久久91精品国产91久久小草| 国产精品成人99久久久久| 久久精品夜色噜噜亚洲A∨| 久久婷婷人人澡人人爽人人爱| 狠狠色丁香久久婷婷综| 伊人久久大香线蕉AV一区二区| 无码人妻久久一区二区三区 | 区久久AAA片69亚洲| 狠狠久久亚洲欧美专区| 久久香综合精品久久伊人|