3

我有一个带有方法的类,我也希望能够将其用作谓词。

class MyClass {
  bool ParticleHasAncestor(const Particle &particle, int id) const;

  class AncestorPredicate {
    int mId;
   public:
    AncestorPredicate(int idCode) : mId(idCode) { }
    bool operator()(const Particle &particle) const { return ParticleHasAncestor(particle, mId); }
  };
};

但是,编译器抱怨没有ParticleHasAncestor()MyClass 的实例就无法使用。我需要使用朋友课程吗?或者有更好的解决方案吗?

我没有使用 C++11,所以不能使用 lambda 函数。

更新: ParticleHasAncestor()不能设为静态,因为它使用 MyClass 的成员。

4

2 回答 2

5

使这个谓词成为一个静态方法。但那时不可能const

于 2013-08-29T11:32:38.843 回答
0

与 Java 不同,在 C++ 中,内部类不拥有指向外部类的指针。

MyClass::AncestorPredicate, 没有 的实例,并且您不能在没有指向该类对象的指针MyClass的情况下调用非静态方法。MyClass

你有两个选择:

首先。制作MyClass::ParticleHasAncestor一个静态方法MyClass

class MyClass {
    static bool ParticleHasAncestor(const Particle &particle, int id);

    class AncestorPredicate {
        int mId;
    public:
        AncestorPredicate(int idCode) : mId(idCode) { }
        bool operator()(const Particle &particle) const 
        { 
            return MyClass::ParticleHasAncestor(particle, mId);
        }
    };
};

第二。创建 的实例MyClass并将指针传递给AncestorPredicate,以便您可以ParticleHasAncestor在该对象上调用:

class MyClass {
    bool ParticleHasAncestor(const Particle &particle, int id) const;

    class AncestorPredicate {
        int mId;
        const MyClass* obj;
    public:
        AncestorPredicate(int idCode, const MyClass* _obj) : mId(idCode), obj( _obj ) { }
        bool operator()(const Particle &particle) const 
        { 
            return obj -> ParticleHasAncestor(particle, mId);
        }
    };
};
于 2013-08-29T11:39:18.537 回答