如何从C ++内部类引用封闭实例?

时间:2011-06-01 08:21:18

标签: c++ this inner-classes

在C ++中,对象通过this引用自身。

但是内部类的实例如何引用其封闭类的实例?

class Zoo
{
    class Bear 
    {
        void runAway()
        {
            EscapeService::helpEscapeFrom (
                this, /* the Bear */ 
                ??? /* I need a pointer to the Bear's Zoo here */);
        }
    };
};

修改

我对非静态内部类如何工作的理解是Bear可以访问其Zoo的成员,因此它具有指向Zoo的隐式指针。在这种情况下我不想访问成员;我正试图得到那个隐含的指针。

7 个答案:

答案 0 :(得分:16)

与Java不同,C ++ 中的内部类没有对其封闭类的实例的隐式引用。

您可以通过传递实例来模拟这个,有两种方法:

转到方法:

class Zoo
{
    class Bear 
    {
        void runAway( Zoo & zoo)
        {
            EscapeService::helpEscapeFrom (
                this, /* the Bear */ 
                zoo );
        }
    };
}; 

传递给构造函数:

class Zoo
{
    class Bear
    {
        Bear( Zoo & zoo_ ) : zoo( zoo_ ) {}
        void runAway()
        {
            EscapeService::helpEscapeFrom (
                this, /* the Bear */ 
                zoo );
        }

        Zoo & zoo;
    };
}; 

答案 1 :(得分:7)

内部类不是特殊的,并且没有任何内置的外部类的链接。如果要访问外部类,则传递指针或引用,就像使用任何其他类一样。

答案 2 :(得分:6)

内部类可以访问外部类的所有成员,但它没有对父类实例的隐式引用。

回答你修改后的问题:
不,你无法访问该隐式指针。我相信人们可以在Java中这样做但不能在C ++中这样做。

您必须通过构造函数或其他函数显式传递外部类对象才能实现此目的。

从技术上讲,根据 C ++ 03标准(sec 11.8.1) ,嵌套类对其封闭类没有特殊访问权限。

但也存在这个标准缺陷:openstd.org/jtc1/sc22/wg21/docs/cwg_defects.html#45不确定是否已关闭。

答案 3 :(得分:4)

您可以使用offsetof从内部类实例访问外部类实例 与指针/参考解决方案相比,这具有零开销 这有点脏,但它完成了工作 例如:

#include <cstddef>
struct enclosing {
    struct inner {
        enclosing& get_enclosing() {
            return *(enclosing*)((char*)this - offsetof(enclosing, i));
        }
        void printX() {
            std::cout << get_enclosing().x << '\n';
        }
    } i;
    int x;
};
int main() {
    enclosing e;
    e.x = 5;
    e.i.printX();
}

P.S。
offsetof对类型做出一些假设。在C ++ 98中,类型必须是POD,而在C ++ 11中,类型必须是“标准布局” 以下是参考:http://www.cplusplus.com/reference/cstddef/offsetof/

答案 4 :(得分:2)

没有内置机制来实现这一目标。您需要通过构造函数或某种SetParent函数自己提供指针。

答案 5 :(得分:2)

C ++标准说(第11.8.1节[class.access.nest]):

  

嵌套类的成员没有   特殊访问成员   封闭类,也不是类或   授予友谊的功能   到一个封闭的班级;通常   准入规则(第11条)应为   服从。 封闭的成员   class没有特殊的访问权限   嵌套类的成员;通常   准入规则(第11条)应为   服从。

(我强调)。

这意味着嵌套类和封闭类之间没有特殊关系。

答案 6 :(得分:1)

在创建嵌套类的实例时,没有隐式创建的封闭类实例。它必须手动完成。