public const不会覆盖私有const函数?

时间:2013-06-12 14:02:11

标签: c++ const override

我有一个像这样的标题的类:

public:
    const dtMeshTile* getTile(int i) const;

private:
    dtMeshTile* getTile(int i);

当我尝试使用它时:

const dtMeshTile* const tile = navmesh->getTile(i);

我在这个上下文中得到一个“'dtMeshTile * getTile(int)'是私有的”我如何指定公共函数?

3 个答案:

答案 0 :(得分:3)

考虑:

#include <cstdlib>

class Bar {}; 
class Foo 
{
public:
    Foo (Bar& bar)
    :   
        mBar (bar)
    {   
    }   
    const Bar& get() const
    {   
        return mBar;
    }   
private:
    Bar& get()
    {   
        return mBar;
    }   

    Bar& mBar;
};

int main()
{
    Bar bar;
    Foo foo (bar);
    Bar& ref = foo.get();
}

在通话时:const Bar& ref = foo.get();您可能希望调用const版本的get(),因为您要分配const引用。

但事实并非如此。返回类型不是函数(或方法)签名的一部分,因此当编译器在可能的重载列表中查找要调用的函数时,不会考虑返回类型。 (实际上,标准拒绝函数重载,它们仅因返回类型而不同。)

那么,如何编译器决定调用哪个函数?通过查看信息确实可以获得它。 tweo重载在参数方面是相同的(都是void),所以它唯一要做的就是用于进行调用的对象的静态类型:foo。在这种情况下,该静态类型为Foo - 绝对不是const

因此,它尝试调用它唯一的功能:const版本的非get()版本。当然这不会编译,因为那是private

为了这个,可以将静态类型更改为const Foo(或类似的东西),如下所示:

Foo foo (bar);
Bar& ref = foo.get();

或者也许......

Foo foo (bar);
const Bar& ref = static_cast <const Foo&> (foo).get();

但在实践中,我宁愿建议这些函数的名称是明确的,而是依靠这些“技巧”来扭曲编译器来做你想做的事。

答案 1 :(得分:1)

确保navmesh在您的通话环境中是常量。但我不建议使用const_cast,你可以阅读http://www.parashift.com/c++-faq/overview-const.html

答案 2 :(得分:1)

你遇到了一个非常常见的设计流程 - 一个带有混合语义的重载集。 但我想你不能改变课程,只能解决它。

您的问题来自重载解析规则。根据参数选择该函数。只要。私人/公共事物在此阶段被忽略。选择基于之前的类型发生 - &gt;如果它是const T *,则选择第一个函数,对于T *,选择第二个函数。

然后应用评估检查,因此对于后一种情况,您将获得错误报告。要强制执行所需的功能,必须使用强制转换,或者更好地创建自由包装函数

const dtMeshTile* getXXXTile(const XXX* p, int i) {return p->getTitle(i);}

(或参考变种)。

在我的代码库中,第二个函数将具有不同的名称,因为获取可变字符串在语义上是不同的。