C++ 笔试题 ——每天学一点,天天都进步
Posted 程序猿是小贺
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++ 笔试题 ——每天学一点,天天都进步相关的知识,希望对你有一定的参考价值。
- 有一个如下的结构体:
struct A{
long a1;
short a2;
int a3;
int *a4;
};
请问在64位编译器下用sizeof(struct A)计算出的大小是多少?( )
A.24
B.28
C.16
D.18
答案解析
64位系统下指针为8个字节,a1占4字节,a2两字节,由于a3占4字节, a2需要补齐2个字节,对于a1,a2,a3一共开辟了12个字节,由于a4占8个字节,所以a4之后要 补齐4个字节才能是8的整数倍,最后总和为24字节,刚好也是8的倍数,所以最终结构体大小为24字节
- 在C++中的结构体是否可以有成员函数?( )
A.不可以,结构类型不支持成员函数
B.可以有
C.不可以,只有类允许有成员函数
答案解析
A.C语言结构体不支持成员函数,但C++结构体支持,其class与struct本质没有区别,唯一区别 在于默认时class的访问属性为私有,struct为公有
B.正确
C.C++结构体也支持成员函数
- 下列有关this指针使用方法的叙述正确的是( )
A.保证基类保护成员在子类中可以被访问
B.保证基类私有成员在子类中可以被访问
C.保证基类公有成员在子类中可以被访问
D.保证每个对象拥有自己的数据成员,但共享处理这些数据的代码
答案解析
A.基类保护成员在子类可以直接被访问,跟this无关
B.基类私有成员在子类中不能被访问,跟this无关
C.基类共有成员在子类和对象外都可以直接访问,跟this无关
D.this指针代表了当前对象,能够区分每个对象的自身数据,故正确
- 下面描述错误的是( )
A.this指针是非静态成员函数的隐含形参.
B.每个非静态的成员函数都有一个this指针.
C.this指针是存在对象里面的.
D.this指针可以为空
答案解析
A.静态成员函数没有this指针,只有非静态成员函数才有,且为隐藏指针
B.非静态成员函数的第一个参数就是隐藏的this指针
C.this指针在非静态的成员函数里面,对象不存在,故错误
D.单纯的对this赋空是不可以的,不过可以强转直接赋空,不过一般不进行这样的操作
- 下列关于构造函数的描述正确的是( )
A.构造函数可以声明返回类型
B.构造函数不可以用private修饰
C.构造函数必须与类名相同
D.构造函数不能带参数
答案解析
A.构造函数不能有返回值,包括void类型也不行
B.构造函数可以是私有的,只是这样之后就不能直接实例化对象
C.这是必须的啊,谁赞成谁反对?哈哈哈哈
D.构造函数不光可以带参数,还可以有多个构造函数构成重载
- 在函数F中,本地变量a和b的构造函数(constructor)和析构函数(destructor)的调用顺序是: ( )
Class A;
Class B;
void F() {
A a;
B b;
}
A.b构造 a构造 a析构 b析构
B.a构造 a析构 b构造 b析构
C.b构造 a构造 b析构 a析构
D.a构造 b构造 b析构 a析构、
答案解析
构造顺序是按照语句的顺序进行构造,析构是按照构造的相反顺序进行析构。
- 设已经有A,B,C,D4个类的定义,程序中A,B,C,D析构函数调用顺序为?( )
C c;
int main()
{
A a;
B b;
static D d;
return 0;
}
A.D B A C
B.B A D C
C.C D B A
D.A B D C
答案解析
1、类的析构函数调用完全按照构造函数调用的相反顺序进行调用
2、全局对象先于局部对象进行构造
3、静态对象先于普通对象进行构造
所以构造的顺序为 c d a b,因此答案为 B A D C
- 假定MyClass为一个类,则该类的拷贝构造函数的声明语句是( )
A.MyClass(MyClass x)
B.MyClass &(MyClass x)
C.MyClass(MyClass &x)
D.MyClass(MyClass *x)
答案解析
A.参数必须是引用,否则造成无限递归
B.语法错误
C.正确
D.这种写法只是普通的构造函数,不能成为拷贝构造函数
- 拷贝构造函数的特点是( )
A.该函数名同类名,也是一种构造函数,该函数返回自身引用
B.该函数只有一个参数,是对某个对象的引用
C.每个类都必须有一个拷贝初始化构造函数,如果类中没有说明拷贝构造函数,则编译器系统会自动生成一个缺省拷贝构造函数,作为该类的保护成员
D.拷贝初始化构造函数的作用是将一个已知对象的数据成员值拷贝给正在创建的另一个同类的对象
答案解析
A.拷贝构造函数也是一构造函数,因此不能有返回值
B.该函数参数是自身类型的对象的引用
C.自动生成的缺省拷贝构造函数,作为该类的公有成员,否则无法进行默认的拷贝构造
D.用对象初始化对象这是拷贝构造函数的使命,故正确
- 以下代码共调用多少次拷贝构造函数: ( )
Widget f(Widget u)
{
Widget v(u);
Widget w=v;
return w;
}
main(){
Widget x;
Widget y=f(f(x));
}
A.1
B.3
C.5
D.7
答案解析
整个程序分别在,x初始化u、u初始化v、v初始化w、w返回时调用,注意w返回时初始u不在调用拷贝构造函数,第二次调用 f()函数时,相当于u的结合会少调用一次,其他不变,所以总体次数为4+3=7次
- 已知表达式++a中的"++"是作为成员函数重载的运算符,则与++a等效的运算符函数调用形式为( )
A.a.operator++()
B.a.operator++(0)
C.a.operator++(int)
D.operator++(a,0)
答案解析
A.正确
B.operator++()传递了整形参数,故为后置++,错误
C.调用函数传递类型,导致语法错误
D.参数过多,语法错误
- 在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是 ( )
A.无操作数的运算符
B.二元运算符
C.前缀一元运算符
D.后缀一元运算符
答案解析
A.重载为成员函数时,其函数的参数个数与真实的函数参数个数会减少1个,减少的则 通过this指针进行传递,所以无参 则说明有一个参数,故错误
B.无参成员函数相当于有一个参数的全局函数,不能是二元运算符
C.正确
D.区分前缀后缀时,后缀运算需要加一个int参数
- 下列关于赋值运算符“=”重载的叙述中,正确的是( )
A.赋值运算符只能作为类的成员函数重载
B.默认的赋值运算符实现了“深层复制”功能
C.重载的赋值运算符函数有两个本类对象作为形参
D.如果己经定义了复制拷贝构造函数,就不能重载赋值运算符
答案解析
A.因为赋值符号=需要对象进行驱动,所以只能重载为成员函数
B.默认的赋值运算符是按成员成员,属于浅赋值
C.参数只有一个,另一个通过this指针传递
D.两个函数的调用场景不同,相互没有影响
- 若要对data类中重载的加法运算符成员函数进行声明,下列选项中正确的是( )
A.Data operator+(Data);
B.Data operator(Data);
C.operator+(Data,Data);
D.Data+(Data);
答案解析
A.正确
B.语法错误,缺少运算符+
C.成员函数参数过多
D.没有运算符重载关键字operator
以上是关于C++ 笔试题 ——每天学一点,天天都进步的主要内容,如果未能解决你的问题,请参考以下文章