getter和setter的错误

时间:2011-04-11 01:11:08

标签: c++ vector getter-setter

我有一个顶点向量,我希望将vertice.setVisit设置为false或0。我为此定义了一些getter和setter,但是遇到了一些类型错误。代码如下:

//Vector:
std::vector<project3::Vertex<VertexType, EdgeType>*> Vertice1;

//Class containing methods:
template <class VertexType, class EdgeType> class Vertex{
protected:
    //std::vector<std::pair<int, EdgeType>> VertexList;
    VertexType vertice;
    EdgeType edge;
    int num;
    int mark;
    //int status=0;

public:

    void setNum(int){ this.num = num; }
    int getNum() { return num; }
    int getMark(){ return mark; }
    void setVisit(int) { this.mark = mark; }
};

在某些功能中,我将值指定为:

for(int i=0; i<g1.Vertice1.size(); i++)
{
    g1.Vertice1.at(i)->setNum(0);
    g1.Vertice1.at(i)->setVisit(0);
}

以下是编译“this.mark = mark”代码和类中函数定义中“this.num = num”的错误。

Error: left of '.mark' must have class/struct/union
 Error: left of '.num' must have class/struct/union

这不是通过getter和setter分配值的正确方法吗?

3 个答案:

答案 0 :(得分:6)

在C ++中,this是指针类型。试试this->mark(*this).mark

编辑:正如理查德在下面指出的那样,还要确保为您要分配的参数命名。在上下文中,this->mark = markthis->mark = this->mark相同。除非mark是参数,否则this在这种情况下实际上是不必要的。实际上,你可以通过这样的方式在你的例子中一起摆脱this

void setVisit(int newMark) { mark = newMark; }

的问候,
丹尼斯M。

答案 1 :(得分:3)

将setNum和setVisit更改为以下

void setNum(int num) {this->num = num; }
void setVisit(int mark) {this->mark = mark; }

答案 2 :(得分:2)

this是指针,因此您必须使用this->num