转载 很经典的C++笔试题

很经典的C++笔试题(附答案) 收藏

1. 以下三条输出语句分别输出什么?

char str1[] = "abc" ;

char str2[] = "abc" ;

const char str3[] = "abc" ;

const char str4[] = "abc" ;

const char * str5 = "abc" ;

const char * str6 = "abc" ;

cout << boolalpha << ( str1==str2 ) << endl; // 输出什么?

cout << boolalpha << ( str3==str4 ) << endl; // 输出什么?

cout << boolalpha << ( str5==str6 ) << endl; // 输出什么?

 

2. 以下代码中的两个sizeof 用法有问题吗?

void UpperCase( char str[] ) // str 中的小写字母转换成大写字母

{

     for ( size_t i=0; i< sizeof (str)/ sizeof (str[0]); ++i )

     {

         if ( 'a' <=str[i] && str[i]<= 'z' )

         {

              str[i] -= ( 'a' - 'A' );

         }

     }

}

char str[] = "aBcDe" ;

cout << "str 字符长度为: " << sizeof (str)/ sizeof (str[0]) << endl;

UpperCase( str );

cout << str << endl;

 

3. C++ 内建型别AB ,在哪几种情况下B 能隐式转化为A

 

4. 以下代码有什么问题?

struct Test

{

     Test( int ) {}

     Test() {}

     void fun() {}

};

void main( void )

{

     Test a(1);

     a.fun();

     Test b();

     b.fun();

}

 

5. 以下代码有什么问题?

cout << ( true ?1: "0" ) << endl;

               

6. 以下代码能够编译通过吗,为什么?

unsigned int const size1 = 2;

char str1[ size1 ];

unsigned int temp = 0;

cin >> temp;

unsigned int const size2 = temp;

char str2[ size2 ];

 

7. 以下反向遍历array 数组的方法有什么错误?

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 数 组

{

     cout << array [i] << endl;

}

 

8. 以下代码中的输出语句输出吗,为什么?

struct CLS

{

     int m_i;

     CLS( int i ) : m_i(i) {}

     CLS()

     {

         CLS(0);

     }

};

CLS obj;

cout << obj.m_i << endl;

 

9. C++ 中的空类,默认产生哪些类成员函数?

 

10. 以下两条输出语句分别输出什么?

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; // 输出什么?

 

11. 以下代码有什么问题?

typedef vector IntArray;

IntArray array ;

array .push_back( 1 );

array .push_back( 2 );

array .push_back( 2 );

array .push_back( 3 );

// 删除array 数组中所有的2

for ( IntArray::iterator itor= array .begin(); itor!= array .end(); ++itor )

{

     if ( 2 == *itor ) array .erase( itor );

}

 

12. 写一个函数,完成内存之间的拷贝。[ 考虑问题是否全面]

 

答案:

1. 答:分别输出false,false,truestr1str2 都是字符数组,每个都有其自己的存 储区,它们的值则是各存储区首地址,不等;str3str4 同 上,只是按const 语义,它们所指向的数据区不能修改。str5str6 并非数组而是字符指针,并不分配存储区,其后的“abc ” 以常量形式存于静态数据区,而它们自己仅是指向该区首地址的指针,相等。

2. 答:函数内的sizeof 有问题。根据语法,sizeof 如用于数组,只能测出静态数组的大小,无法检测动态分配的或外部数组大小。函数外的str 是一个静态定义的数组,因此其大小为,函数内的str 实 际只是一个指向字符串的指针,没有任何额外的与数组相关的信息,因此sizeof 作用于上只将其当 指针看,一个指针为个字节,因此返回。

3. 答:

a. class B : public A { …… } // B 公有继承自A ,可以是间接继承的

b. class B { operator A( ); } // B 实现了隐式转化为A 的转化

c. class A { A( const B& ); } // A 实现了non-explicit 的参数为B (可 以有其他带默认值的参数)构造函数

d. A& operator = ( const A& ); // 赋值操作,虽不是正宗的隐式类型转换,但也勉强算一个

4. 答:变量b 定义出错。按默认构造函数定义对象,不需要加括 号。

5. 答:三元表达式“?: ”问号后面的两个操作数必须为同一类 型。

6. 答:str2 定义出错,size2 非编译器期间常量,而数组定义要求长度必须为编译期常量。

7. 答:首先数组定义有误,应加上类型参数:vector<int> array 。其次vector::size_type 被定义为unsigned int ,即无符号数,这样做为循环变量的i 为 时再减就会变成最大的整数,导致循环失去控制。

8. 答:不能。在默认构造函数内部再调用带参的构造函数属用户行为而非编译器行为,亦即仅执行函数调用,而不会执行其后 的初始化表达式。只有在生成对象时,初始化表达式才会随相应的构造函数一起调用。

9. 答:

class Empty

{

public :

     Empty();                 // 缺省构造函数

     Empty( const Empty& );  // 拷贝构造函数

     ~Empty();                // 析构函数

     Empty& operator =( const Empty& );  // 赋值运算符

     Empty* operator &();                 // 取址运算符

     const Empty* operator &() const ;    // 取址运算符const

};

10. 答:分别输出falsetrue 。注意转换的应用。(int)a 实际上是以浮点 数a 为参数构造了一个整型数,该整数的值是,(int&)a 则 是告诉编译器将a 当作整数看(并没有做任何实质上的转换)。因为以整数形式存放和以浮点形式存放其 内存数据是不一样的,因此两者不等。对b 的两种转换意义同上,但是的整数形式和浮点形式其内存数据 是一样的,因此在这种特殊情形下,两者相等(仅仅在数值意义上)。

  注意,程序的输出会显示(int&)a=1065353216 , 这个值是怎么来的呢?前面已经说了,以浮点数形式存放在内存中,按ieee754 规定,其内容为x0000803F (已 考虑字节反序)。这也就是a 这个变量所占据的内存单元的值。当(int&)a 出现时,它相当于告诉它的上下文:“把这块地址当做整数看待!不要管它原来是什么。”这 样,内容x0000803F 按 整数解释,其值正好就是(十进制数)。

  通过查看汇编代码可以证实“(int)a 相当于 重新构造了一个值等于a 的整型数”之说,而(int&) 的 作用则仅仅是表达了一个类型信息,意义在于为cout<<== 选择正确的重载版本。

11. 答:同样有缺少类型参数的问题。另外,每次调用“array.erase(itor); ”, 被删除元素之后的内容会自动往前移,导致迭代漏项,应在删除一项后使itor-- ,使之从已经前移 的下一个元素起继续遍历。

12. 答:

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;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值