首頁(yè) - 網(wǎng)校 - 萬(wàn)題庫(kù) - 直播 - 雄鷹網(wǎng)校 - 團(tuán)購(gòu) - 書(shū)城 - ? - 學(xué)習(xí)通 - 導(dǎo)航 -
首頁(yè)網(wǎng)校萬(wàn)題庫(kù)直播雄鷹網(wǎng)校團(tuán)購(gòu)書(shū)城?論壇實(shí)用文檔作文大全寶寶起名
2015中考
法律碩士
2015高考
MBA考試
2015考研
MPA考試
在職研
中科院
考研培訓(xùn)
專升本
自學(xué)考試 成人高考
四 六 級(jí)
GRE考試
攻碩英語(yǔ)
零起點(diǎn)日語(yǔ)
職稱英語(yǔ)
口譯筆譯
申碩英語(yǔ)
零起點(diǎn)韓語(yǔ)
商務(wù)英語(yǔ)
日語(yǔ)等級(jí)
GMAT考試
公共英語(yǔ)
職稱日語(yǔ)
新概念英語(yǔ)
專四專八
博思考試
零起點(diǎn)英語(yǔ)
托?荚
托業(yè)考試
零起點(diǎn)法語(yǔ)
雅思考試
成人英語(yǔ)三級(jí)
零起點(diǎn)德語(yǔ)
等級(jí)考試
華為認(rèn)證
水平考試
Java認(rèn)證
職稱計(jì)算機(jī) 微軟認(rèn)證 思科認(rèn)證 Oracle認(rèn)證 Linux認(rèn)證
公 務(wù) 員
導(dǎo)游考試
物 流 師
出版資格
單 證 員
報(bào) 關(guān) 員
外 銷(xiāo) 員
價(jià)格鑒證
網(wǎng)絡(luò)編輯
駕 駛 員
報(bào)檢員
法律顧問(wèn)
管理咨詢
企業(yè)培訓(xùn)
社會(huì)工作者
銀行從業(yè)
教師資格
營(yíng)養(yǎng)師
保險(xiǎn)從業(yè)
普 通 話
證券從業(yè)
跟 單 員
秘書(shū)資格
電子商務(wù)
期貨考試
國(guó)際商務(wù)
心理咨詢
營(yíng) 銷(xiāo) 師
司法考試
國(guó)際貨運(yùn)代理人
人力資源管理師
廣告師職業(yè)水平
衛(wèi)生資格 執(zhí)業(yè)醫(yī)師 執(zhí)業(yè)藥師 執(zhí)業(yè)護(hù)士
會(huì)計(jì)從業(yè)資格
基金從業(yè)資格
統(tǒng)計(jì)從業(yè)資格
經(jīng)濟(jì)師
精算師
統(tǒng)計(jì)師
會(huì)計(jì)職稱
法律顧問(wèn)
ACCA考試
初級(jí)會(huì)計(jì)職稱
資產(chǎn)評(píng)估師
高級(jí)經(jīng)濟(jì)師
注冊(cè)會(huì)計(jì)師
高級(jí)會(huì)計(jì)師
美國(guó)注冊(cè)會(huì)計(jì)師
審計(jì)師考試
國(guó)際內(nèi)審師
注冊(cè)稅務(wù)師
理財(cái)規(guī)劃師
一級(jí)建造師
安全工程師
設(shè)備監(jiān)理師
公路監(jiān)理師
公路造價(jià)師
二級(jí)建造師
招標(biāo)師考試
物業(yè)管理師
電氣工程師
建筑師考試
造價(jià)工程師
注冊(cè)測(cè)繪師
質(zhì)量工程師
巖土工程師
注冊(cè)給排水
造價(jià)員考試
注冊(cè)計(jì)量師
環(huán)保工程師
化工工程師
暖通工程師
咨詢工程師
結(jié)構(gòu)工程師
城市規(guī)劃師
材料員考試
消防工程師
監(jiān)理工程師
房地產(chǎn)估價(jià)
土地估價(jià)師
安全評(píng)價(jià)師
房地產(chǎn)經(jīng)紀(jì)人
投資項(xiàng)目管理師
環(huán)境影響評(píng)價(jià)師
土地登記代理人
寶寶起名
繽紛校園
實(shí)用文檔
入黨申請(qǐng)
英語(yǔ)學(xué)習(xí)
思想?yún)R報(bào)
作文大全
工作總結(jié)
求職招聘 論文下載 直播課堂
您現(xiàn)在的位置: 考試吧 > 軟件水平考試 > 復(fù)習(xí)資料 > 程序員 > 正文

2015年軟件水平考試程序員精選題(6)

考試吧整理“2015年軟件水平考試程序員精選題(6)”供考生參考,更多軟件水平考試資訊和備考資料請(qǐng)關(guān)注考試吧軟件水平考試網(wǎng)。

  查看匯總:2015軟件水平考試程序員精選題匯總

  含有指針成員的類(lèi)的拷貝

  題目:下面是一個(gè)數(shù)組類(lèi)的聲明與實(shí)現(xiàn)。請(qǐng)分析這個(gè)類(lèi)有什么問(wèn)題,并針對(duì)存在的問(wèn)題提出幾種解決方案。

  template class Array

  {

  public:

  Array(unsigned arraySize):data(0), size(arraySize)

  {

  if(size > 0)

  data = new T[size];

  }

  ~Array()

  {

  if(data) delete[] data;

  }

  void setValue(unsigned index, const T& value)

  {

  if(index < size)

  data[index] = value;

  }

  T getValue(unsigned index) const

  {

  if(index < size)

  return data[index];

  else

  return T();

  }

  private:

  T* data;

  unsigned size;

  };

  分析:我們注意在類(lèi)的內(nèi)部封裝了用來(lái)存儲(chǔ)數(shù)組數(shù)據(jù)的指針。軟件存在的大部分問(wèn)題通常都可以歸結(jié)指針的不正確處理。

  這個(gè)類(lèi)只提供了一個(gè)構(gòu)造函數(shù),而沒(méi)有定義構(gòu)造拷貝函數(shù)和重載拷貝運(yùn)算符函數(shù)。當(dāng)這個(gè)類(lèi)的用戶按照下面的方式聲明并實(shí)例化該類(lèi)的一個(gè)實(shí)例

  Array A(10);

  Array B(A);

  或者按照下面的方式把該類(lèi)的一個(gè)實(shí)例賦值給另外一個(gè)實(shí)例

  Array A(10);

  Array B(10);

  B=A;

  編譯器將調(diào)用其自動(dòng)生成的構(gòu)造拷貝函數(shù)或者拷貝運(yùn)算符的重載函數(shù)。在編譯器生成的缺省的構(gòu)造拷貝函數(shù)和拷貝運(yùn)算符的重載函數(shù),對(duì)指針實(shí)行的是按位拷貝,僅僅只是拷貝指針的地址,而不會(huì)拷貝指針的內(nèi)容。因此在執(zhí)行完前面的代碼之后,A.data和B.data指向的同一地址。當(dāng)A或者B中任意一個(gè)結(jié)束其生命周期調(diào)用析構(gòu)函數(shù)時(shí),會(huì)刪除data。由于他們的data指向的是同一個(gè)地方,兩個(gè)實(shí)例的data都被刪除了。但另外一個(gè)實(shí)例并不知道它的data已經(jīng)被刪除了,當(dāng)企圖再次用它的data的時(shí)候,程序就會(huì)不可避免地崩潰。

  由于問(wèn)題出現(xiàn)的根源是調(diào)用了編譯器生成的缺省構(gòu)造拷貝函數(shù)和拷貝運(yùn)算符的重載函數(shù)。一個(gè)最簡(jiǎn)單的辦法就是禁止使用這兩個(gè)函數(shù)。于是我們可以把這兩個(gè)函數(shù)聲明為私有函數(shù),如果類(lèi)的用戶企圖調(diào)用這兩個(gè)函數(shù),將不能通過(guò)編譯。實(shí)現(xiàn)的代碼如下:

  private:

  Array(const Array& copy);

  const Array& operator = (const Array& copy);

  最初的代碼存在問(wèn)題是因?yàn)椴煌瑢?shí)例的data指向的同一地址,刪除一個(gè)實(shí)例的data會(huì)把另外一個(gè)實(shí)例的data也同時(shí)刪除。因此我們還可以讓構(gòu)造拷貝函數(shù)或者拷貝運(yùn)算符的重載函數(shù)拷貝的不只是地址,而是數(shù)據(jù)。由于我們重新存儲(chǔ)了一份數(shù)據(jù),這樣一個(gè)實(shí)例刪除的時(shí)候,對(duì)另外一個(gè)實(shí)例沒(méi)有影響。這種思路我們稱之為深度拷貝。實(shí)現(xiàn)的代碼如下:

  public:

  Array(const Array& copy):data(0), size(copy.size)

  {

  if(size > 0)

  {

  data = new T[size];

  for(int i = 0; i < size; ++ i)

  setValue(i, copy.getValue(i));

  }

  }

  const Array& operator = (const Array& copy)

  {

  if(this == ©)

  return *this;

  if(data != NULL)

  {

  delete []data;

  data = NULL;

  }

  size = copy.size;

  if(size > 0)

  {

  data = new T[size];

  for(int i = 0; i < size; ++ i)

  setValue(i, copy.getValue(i));

  }

  }

  相關(guān)推薦:

  2015年軟考信息技術(shù)處理員考前知識(shí)點(diǎn)總結(jié)匯總

  2015年軟件水平考試《程序員》提高練習(xí)題匯總

  2015軟件水平考試《程序員》知識(shí)點(diǎn)總結(jié)匯總

文章搜索
軟件水平考試欄目導(dǎo)航
版權(quán)聲明:如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系800@exam8.com,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
Copyright © 2004- 考試吧軟件水平考試網(wǎng) All Rights Reserved 
中國(guó)科學(xué)院研究生院權(quán)威支持(北京)
在線模擬試題
考證通關(guān)殺器
考試最新資訊
學(xué)
一次通關(guān)技巧