1. 以下程序运行后的输出结果是
a=d/10%9,由于/是除法运算符,%(两边必须是整数)是取余运算符。
这两个运算符都是同一优先级,都是左结合,那么就表示d除以10所得到的整数再除以9取余数。
由于d=25,那么a=25/10%9=2%9=2
注意 x%y如果x
2. 下列代码运行的结果为
当父类指针(引用)指向子类对象时,子类对象退化成父类对象,只能访问父类中定义的成员
如果B对象没有virtual修饰的话,B* pb = ⅆ dd就会退化为父类对象,pd就只能访问父类的成员B::Fun()
但是又virtual修饰的话,就会展现多态行为,会根据实际指针指向的对象判断函数的调用。pb 和pd都指向子类对象,所以调用D::Fun()
基类虚函数Fun的子类可以覆盖Fun函数,此时无论父类还是子类实例都可以调用Fun函数,如果存在多个子类覆盖Fun函数,那么可以利用多态机制灵活地调用不同子类的Fun函数
3. 设已定义浮点型变量data,以二进制代码方式把data的值写入输出文件流对象outfile中,正确的语句是()
这里考察的是write的第二种用法:
write(const char* str, int n)
其中,str是字符指针或字符数组,用来存放一个字符串;
n是int型数,它用来表示输出显示字符串中字符的个数
第1个参数是字符串的地址,第2个参数表示字符串的字符个数
data的地址转换为char*型,认为是字符串类型
至于为什么第2个参数是sizeof(double);
main() {
int a, b, d = 25;
a = d/10%9;
b = a && (-1);
printf("%d,%d\n", a, b);
}
- 6,1
- 2,1
- 6,0
- 2,0
a=d/10%9,由于/是除法运算符,%(两边必须是整数)是取余运算符。
这两个运算符都是同一优先级,都是左结合,那么就表示d除以10所得到的整数再除以9取余数。
由于d=25,那么a=25/10%9=2%9=2
注意 x%y如果x
2. 下列代码运行的结果为
class B
{
public:
virtual void Fun(){
}
};
class D: public B
{
public:
void Fun(){
}
};
D dd;
B* pb = ⅆ
D* pd = ⅆ
pb->Fun();
pd->Fun();
- B::Fun, D::Fun
- B::Fun, B::Fun
- D::Fun, D::Fun
- D::Fun, B::Fun
当父类指针(引用)指向子类对象时,子类对象退化成父类对象,只能访问父类中定义的成员
如果B对象没有virtual修饰的话,B* pb = ⅆ dd就会退化为父类对象,pd就只能访问父类的成员B::Fun()
但是又virtual修饰的话,就会展现多态行为,会根据实际指针指向的对象判断函数的调用。pb 和pd都指向子类对象,所以调用D::Fun()
基类虚函数Fun的子类可以覆盖Fun函数,此时无论父类还是子类实例都可以调用Fun函数,如果存在多个子类覆盖Fun函数,那么可以利用多态机制灵活地调用不同子类的Fun函数
3. 设已定义浮点型变量data,以二进制代码方式把data的值写入输出文件流对象outfile中,正确的语句是()
- outfile.write((double ) &data, sizeof(double));
- outfile.write((double ) &data, data);
- outfile.write((char *) &data, sizeof(double));
- outfile.write((char *) &data, data);
这里考察的是write的第二种用法:
write(const char* str, int n)
其中,str是字符指针或字符数组,用来存放一个字符串;
n是int型数,它用来表示输出显示字符串中字符的个数
第1个参数是字符串的地址,第2个参数表示字符串的字符个数
data的地址转换为char*型,认为是字符串类型
至于为什么第2个参数是sizeof(double);
int i;
sizeof(