奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

試題

計算機二級《C++》上機模擬題及答案

時間:2024-08-16 07:15:26 試題 我要投稿
  • 相關推薦

2017計算機二級《C++》上機模擬題及答案

  為幫助各位考生順利備考計算機二級《C++》考試,掌握所學知識點,以下是百分網小編搜索整理的一份2017計算機二級《C++》上機模擬題及答案,供參考練習,預祝考生們考出自己理想的成績!想了解更多相關信息請持續關注我們應屆畢業生考試網!

  選擇題(每小題1分,共40分)

  1下列有關內聯函數的敘述中,正確的是( )。

  A.內聯函數在調用時發生控制轉移

  B.內聯函數必須通過關鍵字inline來定義

  C.內聯函數是通過編譯器來實現的

  D.內聯函數函數體的最后一條語句必須是return語句

  參考答案:C

  參考解析:一般函數進行調用時,要將程序執行權轉到被調用函數中,然后再返回到調用它的函數中;而內聯函數在調用時,是將調用表達式用內聯函數體來替換,所以在調用時不發生控制轉移。在類內部實現的函數都是內聯函數,可以不用inline定義;只有函數外部定義的內聯函數才必須加關鍵字inline。編譯系統并非對內聯函數必須使用內聯,而且根據具體情況決定。內聯函數不是必須要有返回值的。

  2語句int*P=&k;定義了指針P,與這個語句等效的語句序列是( )。

  A.int* p;P=&k;B.int * P;P=k;C.int * p;* P=&k;D.int * p;* P=k;

  參考答案:A

  參考解析:本題考查指針和地址,題目中定義了一個指向變量k的一個指針p,那么與題目中等效的表達式A選項,即先定義一個指向整型的指針,然后指向k的地址。

  3有如下程序:

  #include

  using namespace std;

  class A

  {

  public:

  A(){cout<<”A”;}

  -A(){cout<<”-A”;}

  };

  class B:public A

  {

  A*P;

  public:

  B(){cout<<”B”;P=new A();}

  -B(){cout<<”~B”; p;}

  };

  int main()

  {

  B obj;

  return 0;

  }

  執行這個程序的輸出結果是( )。

  A.BAA~A~B~AB.ABA~B~A~AC.BAA~B~A~AD.ABA~A~B~A

  參考答案:B

  參考解析:本題考查派生類的構造函數和析構函數,在定義一個派生類的對象時,先調用基類的構造函數,然后再執行派生類的構造函數。對象釋放時,先執行派生類的析構函數,再執行基類的析構函數。所以本題答案為B。

  4有如下類定義:

  class AA

  {

  im a:

  public:

  int getRef()const{return&a;}//①

  int getValue()const{return a;}//②

  void set(int n)const{a=n;}//③

  friend void show(AA aA.const{cout<

  };

  其中四個函數的定義中正確的是(  )。

  A.①B.②C.③D.④

  參考答案:B

  參考解析:本題考查常成員函數,常成員函數只能引用本類中的數據成員,而不能修改它。所以本題答案為B。

  5若要對Data類中重載的加法運算符成員函數進行聲明,下列選項中正確的是( )。

  A.Data+(DatA.;B.Data operator+(DatA.;C.Data+operator(DatA.;D.operator+(Data,DatA.;

  參考答案:B

  參考解析:根據重載加法運算符的格式,只有B選項正確。

  6有如下數組聲明:int num[10];,下標值引用錯誤的是( )。

  A.num[10]B.num[5]C.num[3]D.hum[o]

  參考答案:A

  參考解析:數組定義中的數字指的是數組的大小,而下標是從0開始的,所以本題中數組的最后一個元素是num[9]。

  7將前綴運算符“--”重載為非成員函數,下列原型中能正確用于類中說明的是(  )。

  A.DeCr&operator--(int);B.DeCr operator--(DeCr&,int);C.friend DeCr&operator--(DeCr&);D.friend DeCr operator--(DeCr&,int);

  參考答案:C

  參考解析:把“--”運算符重載為非成員(友元)函數格式:friend<返回類型>operator--()是前綴的格式;friend<返回類型>operator--(int)是后綴的格式。當然也可以有參數如題中C選項所示。

  8如果派生類以proteCted方式繼承基類,則原基類的proteCted成員和publiC成員在派生類中的訪問屬性分別是( )。

  A.publiC和publiCB.publiC和proteCtedC.proteCted和publiCD.proteCted和proteCted

  參考答案:D

  參考解析:本題考查保護繼承中派生類對基類的訪問屬性,在受保護繼承中,基類的公用成員和保護成員在派生類中成了保護成員,其私有成員仍為基類私有,所以本題答案為D。

  9在函數中,可以用aut0、extem、register和static這四個關鍵字中的一個來說明變量的存儲類型,如果不說明存儲類型,則默認的存儲類型是(  )。

  A.autoB.externC.registerD.static

  參考答案:A

  參考解析:變量的存儲方法分為靜態存儲和動態存儲兩大類,包含4種:自動的(auto)、靜態的(static)、寄存器的(register)、外部的(extem)。變量如果沒有說明存儲類型,那么默認就是aut0。

  10下列程序的輸出結果是( )。

  #include

  int rain(iltl a,int B)

  {

  if(a

  else retum b;

  retum 0;

  }

  void main()

  {

  eout<

  }

  A.0B.1C.2D.3

  參考答案:B

  參考解析:本題考查的是函數的調用,第一次調用min(2,3),因為2<3,所以返回值為2,第二次調用min(1,2),因為l<2,所以返回1。

  11在黑盒測試方法中,設計測試用例的主要根據是( )。

  A.程序內部邏輯B.程序外部功能C.程序數據結構D.程序流程圖

  參考答案:B

  參考解析:黑盒測試是對軟件已經實現的功能是否滿足需求進行測試和驗證,黑盒測試完全不考慮程序內部的邏輯結構和內部特性,只根據程序的需求和功能規格說明,檢查程序的功能是否符合它的功能說明,所以本題選擇B。

  12在面向對象方法中,不屬于“對象”基本特點的是(  )。

  A.一致性B.分類性C.多態性D.標識唯一性

  參考答案:A

  參考解析:對象有如下一些基本特點:標識唯一性、分類性、多態性、封裝性、模塊獨立性好。所以選擇A。

  13有以下程序:

  #include

  void fun(int a,int b,int C.

  { a=456,b=567,c=678;}

  void main()

  {

  int X=10,Y=20,Z=30;

  fun(X,Y,z);

  aout<

  }

  輸出結果是( )。

  A.30,20,10B.10,20,30C.456,567,678D.678,567,456

  參考答案:B

  參考解析:本題考查函數中變量的作用范圍,在主函數中給變餐x、Y、Z賦值,然后將其作為實參傳遞給了函數fun(),雖然在函數fun()中改變了這3個變量的值,但只是同名的局部變量,不影響函數中變量的值,所以在調用函數fun()結束后,主函數3個變量的值未改變。

  14對類的構造函數和析構函數描述正確的是( )。

  A.構造函數可以重載,析構函數不能重載

  B.構造函數不能重載,析構函數可以重載

  C.構造函數可以重載,析構函數也可以重載

  D.構造函數不能重載,析構函數也不能重裁

  參考答案:A

  參考解析:一個類中只能定義一個析構函數,否則會造成對同…對象的多次刪除;而構造函數可以根據不同的參數個數和類型進行多次重載。

  15通過運算符重載,可以改變運算符原有的(  )。

  A.操作數類型B.操作數個數C.優先級D.結合性

  參考答案:A

  參考解析:重載運算符的規則如下:①c++不允許用戶自己定義新的運算符,只能對已有的C++運算符進行重載;②C++不能重載的運算符只有5個;③重載不能改變運算符運算對象的個數;④重載不能改變運算符的優先級和結合性;⑤重載運算符的函數不能有默認的參數;⑥重載的運算符必須和用戶定義的自定義類型的對象一起使用,至少應有一個是類對象,即不允許參數全部是c++的標準類型。故本題答案為A。

  16下列關于c++流的描述中,錯誤的是(  )。

  A.cout>>’A’表達式可輸出字符A

  B.eof()函數可以檢測是否到達文件尾

  C.對磁盤文件進行流操作時,必須包含頭文件fstream

  D.以ios_base::0ut模式打開的文件不存在時,將自動建立一個新文件

  參考答案:A

  參考解析:本題考查c++流,想要輸出字符“A”,則應該是cout<<“A”,所以本題答案為A。

  17耦合性和內聚性是對模塊獨立性度量的兩個標準。下列敘述中正確的是(  )。

  A.提高耦合性降低內聚性有利于提高模塊的獨立性

  B.降低耦合性提高內聚性有利于提高模塊的獨立性

  C.耦合性是指一個模塊內部各個元素間彼此結合的緊密程度

  D.內聚性是指模塊間互相連接的緊密程度

  參考答案:B

  參考解析:模塊獨立性是指每個模塊只完成系統要求的獨立的子功能,并且與其他模塊的聯系最少且接口簡單。一般較優秀的軟件設計,應盡量做到高內聚、低耦合,即減弱模塊之間的耦合性和提高模塊內的內聚性,有利于提高模塊的獨立性,所以A錯誤,B正確。耦合性是模塊間互相連接的緊密程度的度量而內聚性是指一個模塊內部各個元素間彼此結合的緊密程度,所以C與D錯誤。

  18若有如下類聲明:

  Class MyClass{ publiC:

  MyClass(  ){Cout<<1;} };

  執行下列語句

  MyClass a,b[2],*p[2]; 程序的輸出結果是(  )。

  A.11B.111C.1111D.11111

  參考答案:B

  參考解析:本題考查默認構造函數和帶參數的構造函數,題目中定義一一個對象a以及對象數組b[2],共執行3次構造函數,對象指針不調用構造函數。所以本題答案為B。

  19下列函數模板的定義中,合法的是(  )。

  A.templateT abs(T X){return x<07-x:X;}

  B.template ClassT abs(T x){return x<07-X:x;}

  C.template Tabs(T X){return x<07-x:X;}

  D.template T abs(T x){return X<0?-X:x;}

  參考答案:A

  參考解析:本題考查模板函數的基本概念.根據模板函數的定義,所以答案為A。

  20有如下程序:

  #include

  using namespace std;

  class Base{

  int x:

  public:

  Base(int n=0):x(n){cout<

  int getX()const{return x;}

  };

  cjass Derived:public Base{

  int Y:.

  J;;Iublic:

  Derived(int m,int n):y(m),Base(n){cout<

  Derived(int m):Y(m){cout<

  };

  int main()

  {

  Derived dl(3),d2(5,7);

  retum 0;

  }

  執行這個程序的輸出結果是( )。

  A.375B.357C.0375D.0557

  參考答案:C

  參考解析:本題考查派生類的構造函數和析構函數,在定義一個派生類的對象時,先調用基類的構造函數,然后再執行派生類的構造函數,對象釋放時,先執行派生類的析構函數。再執行基類的析構函數。本題中定義了一個對象d1,先執行基類的構造函數輸出0,再執行派生類的構造函數輸出3,然后定義了一個對象d2(5,7),其中需要調用基類的構造函數輸出7.最后輸出5,所以答案為c。

  21關于在調用模板函數時模板實參的使用,下列表述中正確的是(  )。

  A.對于虛擬類型參數所對應的模板實參,如果能從模板函數的實參中獲得相同的信息,則都可以省略

  B.對于虛擬類型參數所對應的模板實參,如果它們是參數表中的最后的若干個參數,則都可以省略

  C.對于虛擬類型參數所對應的模板實參,若能夠省略則必須省略

  D.對于常規參數所對應的模板實參,任何情況下都不能省略

  參考答案:D

  參考解析:在調用一個模板函數時,編譯系統需要足夠的信息來判別每個虛擬類型參數所對應的實際類型,可以從兩個不同的渠道獲得這樣的信息:從模板實參表(用“<>”括起來的參數表)或從模板函數實參表(用“()”括起來的參數表)。如果從后者獲得的信息已經能夠判定其中部分或全部虛擬類型參數所對應的實際參數,而且它們又正好是參數表中最后的若干參數,則模板實參表中的那幾個參數可以省。如果模板實參表中的實參都被省了,則空表“<>”也可以不要,因此選項D錯誤。反之,對于某個模板實參,如果從模板函數的實參表中無法獲得同樣的信息,就不能省;或者雖然能夠獲得同樣的信息,但在它后面還有其他不能省的實參,則其自身還是不能省。

  22有如下程序段:

  int i=0,J=1;

  int&r=i;//①

  r=j;//②

  int*P=&i;//⑧

  *P=&r;//④

  其中會產生編譯錯誤的語句是(  )。

  A.④B.③C.②D.①

  參考答案:A

  參考解析:本題考查指針和引用。①為引用,使用正確;④中&r表示一一個地址,而* P已經是一個值了,不能將一個指針賦值給一個值,所以編譯錯誤。

  23有如下程序:

  #include

  using namespace std;

  class Obj{

  static int i;

  public:

  Obj(){i++;}

  一Obj(){i一一;}

  static int getVal(){return i;}

  };

  int Obj::i=0:

  void f(){Obj ob2;cout<

  int main(){

  Obj obl;

  f();

  Obj}ob3=new Obj;cout

   ob3;cout<

  return 0;

  }

  執行這個程序的輸出結果是(  )。

  A.232B.231C.222D.221

  參考答案:D

  參考解析:本題考查構造函數和析構函數的調用順序,調用順序為先構造的后析構,后構造的先析構。本題中先定義了一個對象ob1,會執行構造函數,那么i就變為了l;再執行函數f后,由于又定義了一個對象ob2,所以再次執行構造函數,i就變為了2,輸出了2。函數執行完后執行析構函數,i變為了1,然后又定義了對象指針,i變為了2。釋放ob3后,i變為了1,所以答案為D。

  24有如下類定義:

  class MyBase{

  int k;

  public:

  MyBase(int n=O):k(n)}}

  int value()eonst{return k;}

  };

  class MyDerived:MyBase{

  intj;

  public:

  MyDerived(int i):j(i)}}

  int getK()const{return k;}

  int getJ()const{return j;}

  };

  編譯時發現有一處語法錯誤,對這個錯誤最準確的描述是(  )。

  A.函數9etK試圖訪問基類的私有成員變量k

  B.在類MyDerived的定義中,基類名MyBase前缺少關鍵字public、protected或private

  C.類MyDerived缺少一個無參的構造函數

  D.類MyDerived的構造函數沒有對基類數據成員k進行初始化

  參考答案:A

  參考解析:默認繼承方式為私有繼承,私有繼承將基類的公用成員和保護成員都變為r私有成員,基類的私有成員依然屬于基類私有,派生類不能訪問基類的私有成員。所以A選項正確。

  25下列關于虛基類的描述,錯誤的是( )。

  A.設置虛基類的目的是為了消除二義性

  B.虛基類的構造函數在非虛基類之后調用

  C.若同一層中包含多個虛基類,這些虛基類的構造函數按它們說明的次序調用

  D.若虛基類由非虛基類派生而來,則仍然先調用基類構造函數,再調用派生類的構造函數

  參考答案:B

  參考解析:虛基類的引入就是為j-消除。二義性,其構造函數的調用仍然是按照繼承的順序進行的,對于多個虛基類則按它們說明的次序調用,虛基類的構造函數先于非虛基類的構造函數執行。

  26在長度為n的有序線性表中進行二分查找,最壞情況下需要比較的次數是(  )。

  A.O(n)B.O(n2)C.O(1092n)D.0(n1092n)

  參考答案:C

  參考解析:當有序線性表為順序存儲時才能用:二分法查找。可以證明的是對于長度為n的有序線性表,在最壞情況下,二分法查找只需要比較l092n次,而順序查找需要比較n次。

  27在軟件開發中,需求分析階段可以使用的工具是(  )。

  A.N—s圖B.DFD圖C.PAD圖D.程序流程圖

  參考答案:B

  參考解析:在需求分析階段可以使用的工具有數據流圖DFD圖,數據字典DD,判定樹與判定表,所以選擇B。

  28有如下類聲明:

  class Base{

  protected:

  int amount;

  public:

  Base(int n=0):amount(n){}

  int getAmount()const{retum amount;}

  };

  class Derived:public Base{

  protected:

  int value;

  public:

  Derived(int m,int n):value(m),Base(n){}

  int getData()const{return value+amount;}

  }:

  已知x是一個Derived對象,則下列表達式中正確的是( )。

  A.x.value+X.getAmount()B.x.getData()一x.getAmount()C.x.getData()一x.amountD.x.value+X.amount

  參考答案:B

  參考解析:本題考查公有繼承中派生類對象對基類的訪問屬性。在公有繼承中,派生類對象只能訪問基類的公有成員,而不能}方問基類的保護成員和私有成員。題中x是派生類的對象,只能訪問基類中公有的Base()和getAmount()成員,而不能訪問保護類型的amount成員,故選項C、D錯誤。而類對象對類成員的訪問也存在類似的情況,即類對象只能訪問類的公有成員,而value是Derived的保護成員,所以A選項也錯誤。故答案為B。


主站蜘蛛池模板: 成都市| 锦屏县| 石泉县| 海淀区| 凉山| 安多县| 上高县| 越西县| 台州市| 天全县| 甘德县| 阳谷县| 西贡区| 环江| 新巴尔虎左旗| 亳州市| 安仁县| 丁青县| 镇远县| 洞口县| 凭祥市| 衡阳市| 柳江县| 枣阳市| 陇南市| 天水市| 阜城县| 高台县| 南木林县| 定边县| 荔波县| 五指山市| 神农架林区| 兴文县| 新宁县| 汤原县| 怀安县| 子长县| 南充市| 万年县| 定远县|