13

我有以下无法编译的代码示例:

#include <stdio.h>

namespace my
{
    class base1
    { // line 6
    };

    class base2: private base1
    {
    };

    class derived: private base2
    {
    public:
        // The following function just wants to print a pointer, nothing else!
        void print(base1* pointer) {printf("%p\n", pointer);}
    };
}

gcc 打印的错误是:

test.cpp:6: 错误: `class my::base1' 不可访问

test.cpp:17:错误:在此上下文中

现在,我可以猜到问题出在哪里:当查看 的声明时print,编译器看到base1并认为:base1是 的基类子对象derived* this,但您无权访问它!虽然我打算这base1应该只是一个类型名称。

我如何在 C++ 标准中看到这是正确的行为,而不是编译器中的错误(我确信这不是错误;我检查过的所有编译器都是如此)?

我应该如何解决这个错误?以下所有修复都有效,但我应该选择哪一个?

无效打印(base1* 指针){}

无效打印(::my:: base1* 指针){}

类基1; 无效打印(base1* 指针){}


编辑:

int main()
{
    my::base1 object1;
    my::derived object3;
    object3.print(&object1);
}
4

1 回答 1

12

您要查找的部分是 11.1。它建议使用 ::my::base1* 来解决这个问题:

[注意:在派生类中,基类名称的查找将找到注入的类名称,而不是在声明它的范围内的基类名称。在声明它的范围内,注入的类名可能比基类的名称更难访问。——尾注]

[ Example:
class A { };
class B : private A { };
class C : public B {
A *p;
// error: injected-class-name A is inaccessible
:: A * q ;
// OK
};
于 2011-04-12T11:53:30.887 回答