派生类对基类的访问

派生类对基类的访问

class Base
{
   foo(int);
protected:
   int bar;
   double foo_bar;
};

class Derived : public Base
{
   foo(string);
   bool bar(Base *pb);
   void foobar();
protected:
   string bar;
}; 

 

以下错误
bool Derived::bar(Base *pb)
{ return foo_bar == pb-> foo_bar; }
通过指向基类对象的指针访问其受保护成员难道错了?

 

现在让我们来谈谈protected这个关键字吧,它的意思是:对对象来说,声明为protected的变量是私有的,而对子类父类来说,声明为protected的变量是公共的。

派生类对其基类类型对象的protected成员没有特殊访问权限,所以在派生类的函数中通过基类的对象来访问protected成员是非法的
bool Derived::bar(Base *pb) 虽然说形式参数是基类指针,在派生类的函数中是不可访问基类的保护成员,和私有成员.是非法的.

派生类的成员可以访问基类的protected成员(因为派生类成员在派生类的内部)
派生类的对象不可以访问基类的protected成员(因为派生类对象在应用程序域,已经出了类内部域)
派生类的的对象只能访问各种类的公有成员,或通过公有成员函数间接访问私有或受保护的成员

 

//基类对象对派生类对象的切割问题
class Window
{
public:
 std::string name() const;
 virtual void display() const { cout << "Window.display"; };
};

class WindowWithScrollBars: public Window
{
public:
 virtual void display() const { cout << "WindowWithScrollBars.display"; };
};

void printNameAndDisplay(Window w)
{
 std::cout << w.name();
 w.display();
}

//调用
WindowWithScrollBars wwsb;
printNameAndDisplay(wwsb);  
//输出:
WindowWithScrollBars.display
//当一个derived class 对象以by value 方式传递并被视为一个base class 对象,base class 的拷贝构造函数
//会被调用,而“造成此对象的行为像个derived class 对象”的那些特化性质全被切割掉了,仅仅留下一个
//base class 对象,因为正是base class 构造函数建立了它。
// 避免切割问题,可用 pass-by-reference-to-const 代替 pass-by-value。即

void printNameAndDisplay(const Window &w)
{
 std::cout << w.name();
 w.display();
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值