0
    class Base
    {  
         int iBase;

      public:           
         virtual void display()
         {
            cout<<"I am a Base Class"<<endl;
         }        
    };

    class Derived : public Base
    { 
        int iDerived;

     public:
        Derived()
        {
            cout<<"In Derived Default Constructor"<<endl;
            iDerived=10;
        }   

        void display()
        {
            cout<<"I am in Derived Class"<<endl;
            cout<<"value of iDerived  :"<<iDerived<<endl;
            iDerived=100;
            cout<<"value of iDerived  :"<<iDerived<<endl;
        }                
   };

在主要:

     Base *varBase;
     Derived varDerived;

     varBase = &varDerived;
     varBase->display();
     varBase->iDerived=10; // Error: iDerived is not a member of Base: ?????

大家好,

我正在尝试了解对象切片并尝试使用一些示例程序。

我在某处读到了指针引用 Objcet Slicing 不会发生。

但是在下面的示例中,我注意到iDerived无法从 访问Base pointer(varBase),但是virtual display method of class即使它不在显示方法的本地范围内,我也可以访问。

现在我的问题是:

  1. 为什么我只能使用虚函数访问 iDerived 变量,这是否正确?
  2. 如何避免对象切片。
4

2 回答 2

2

您的示例代码根本不涉及切片。您所做的只是调用基本的多态性。通过声明Base::display()asvirtual和调用display()a ,您已经要求它以所指向对象的实际Base *类型动态调用成员函数,即. 的成员变量在 的范围内,这就是它编译和工作的原因。DerivedDerivedDerived::display()

但是,您只能通过指针直接访问在BaseBase中声明的成员变量(或函数) 。这就是为什么varBase->iDerived不编译。

切片通常涉及以下内容:

Derived d;
Base b = (Base)d;

通过显式分配/初始化一个Base对象,所有Derived特定的成员都将丢失(即它们已被“切片”掉)。

这个东西比较基础;我建议买一本关于 C++ 的不错的书。这里有一个很好的列表:The Definitive C++ Book Guide and List

于 2011-01-24T08:51:19.447 回答
0

C++ 有虚函数,但没有虚数据。

您可以添加以下内容来模拟它:

class Base {
  // What you had before
  virtual int getAnInt() const = 0; // =0 means that Derived must implement this
};
class Derived {
  // What you had before
  virtual int getAnInt() const { return iDerived; }
};

对象切片完全不相关,并且在您的示例中不会发生。

于 2011-01-24T09:03:35.393 回答