1.已知表达式++a中的"++"是作为成员函数重载的运算符,则与++a等效的运算符函数调用形式为()
a.operator++()
a.operator++(0)
a.operator++(int)
operator++(a,0)
C++规定:
++a 前缀运算符 a.operator() 不需要加参数。
a++后缀运算符 a.operator(int) 需要加参数。
2.在x86的机器上,int a=0xabcd1234 char b=((char*)&a)[0]请问b是多少
-
0xa
-
0x4
-
0xab
-
0x34
解答:D
x86是小端存储,即高位存储在高地址,低位存储在低地址。int类型数据占4个字节,char占1个字节。
int a = 0xabcd1234;//这里0x34是一个字节,0x12,0xcd,0xab也都是一个字节
内存中 ab cd 12 34,b作为一个char,指向第一个内存区域,也就是低地址,右边表达式指针指向为0x34.
3.
有这样一个类:
有这样一个类:
class Eye
{
public:
void Look(void);
};
现在希望定义一个Head类,也想实现Look的功能,应该使用()方法,实现代码重用。
A:继承
B:组合
C:模板
D:过滤
解答:B
组合是在新类中以原有类的对象作为数据成员,继承是在不改变现有的类的基础上,采用现有类的形式并在其中添加新代码,组合一般用于在新类中使用现有类的功能而不是他的接口的情况,就是新类用户看到的只是为新类所定义的接口。而继承则是用于在新类需要向基类转化的情况(多态),这也是组合和继承使用的最清晰的判断方法。
结合本题分析,我们只需让眼睛作为头的一个成员即可,而让头去继承眼睛的特性是没有必要的。
详解继承与组合的优缺点