更多"派生类的对象对它的基类成员中(),是可以访问的。"的相关试题:
[单项选择]可以用p.a的形式访问派生类对象p的基类成员a,其中a是
A. 私有继承的公有成员
B. 公有继承的私有成员
C. 公有继承的保护成员
D. 公有继承的公有成员
[单项选择]在main函数中可以用p.a的形式访问派生类对象p的基类成员a,其中a是( )
A. 私有继承的公有成员
B. 公有继承的私有成员
C. 公有继承的保护成员
D. 公有继承的公有成员
[单项选择]派生类对象对其基类中的什么成员是可访问的( )
A. 公有继承的私有成员
B. 私有继承的公有成员
C. 私有继承的保护成员
D. 保护继承的保护成员
[单项选择]派生类的对象对它的基类成员中( )是可以访问的。
A. 公有继承的公有成员 B) 公有继承的私有成员
B. 公有继承的保护成员 D) 私有继承的公有成员
[单项选择]如果不使用多态机制,那么通过基类的指针虽然可以指向派生类对象,但是只能访问从基类继承的成员。有如下程序,没有使用多态机制。
#include <iostream>
using namespace std;
class Base f
int a,b;
public:
Base(int x,int y)a=x; b=y;
void show( )cout<<a<<','<<b<<endl;
;
class Derived:public Base
int c,d;
public:
Derived(int x,int y,int z,int m):Base(x,y) c=z; d=m;
void show( ) cout<<c<<','<<d<<endl;
;
int main( )
Base B1(50,50), *pb;
Derived D1(10,20,30,40);
pb=&D1;
pb->show( );
return 0;
运行时输出的结果是( )。
A. 10,20
B. 30,40
C. 20,30
D. 50,50
[填空题]
如果不使用多态机制,那么通过基类的指针虽然可以指向派生类对象,但是只能访问问从基类继承的成员。下列程序没有使用多态机制,其输出结果是 【11】 。
#include <iostream>
using namespace std;
class Base {
public:
void print ( ) {cout << ’B’; }};
class Derived: public Base {
public:
void print ( ) {cout <<’D’;}};
int main( )
{
Derived* pd = new Derived( );
Base* pb = pd;
pb->print( );
pd->print( );
delete pd;
return 0;
}
[单项选择]通过公有派生类的对象,只能访问基类成员中的( )。
A. 公有成员
B. 私有成员
C. 保护成员
D. 公有成员和保护成员
[单项选择]若要用派生类的对象访问基类的保护成员,以下观点正确的是( )
A. 可采用公有继承
B. 可采用私有继承
C. 可采用保护继承
D. 不可能实现
[单项选择]在公有派生情况下,有关派生类对象和基类对象的关系,下列叙述不正确的是
A. 派生类的对象可以赋给基类的对象
B. 派生类的对象可以初始化基类的引用
C. 派生类的对象可以直接访问基类中的成员
D. 派生类的对象的地址可以赋给指向基类的指针
[单项选择]建立派生类对象时,3种构造函数分别是a(基类的构造函数)、b(成员对象的构造函数)、c(派生类的构造函数)这3种构造函数的调用顺序为
A. abc
B. acb
C. cab
D. cba
[单项选择]生成派生类对象时,派生类构造函数调用基类构造函数的条件是( )。
A. 无需任何条件
B. 基类中显式定义了构造函数
C. 派生类中显式定义了构造函数
D. 派生类构造函数明确调用了基类构造函数
[单项选择]在公有派生情况下,有关派生类对象和基类对象的关系,不正确的叙述是 ______。
A. 派生类的对象可以赋给基类的对象
B. 派生类的对象可以初始化基类的引用
C. 派生类的对象可以直接访问基类中的成员
D. 派生类的对象的地址可以赋给指向基类的指针