0

您好,我正在开发一个 C++ 程序,我刚开始从我创建的类中创建一些示例对象。我正在创建对象,但由于某种原因,点运算符无法使用该对象

这是对象调用

Card testcard(Suit hearts, Value six);

这是构造函数

Card::Card(Suit suit, Value facevalue)
{
Card::suit=suit;
Card::faceValue=facevalue;
};

但是点运算符不起作用,就好像对象实际上并不存在一样

我在单独的部分中控制大部分程序,因此有许多头文件实例是卡类所在的位置,我不确定这是否是问题的一部分

4

4 回答 4

4

在实例方法中,您不能使用点来访问实例。

请尝试this->

Card::Card(Suit suit, Value facevalue)
{
    this->suit=suit;
    this->faceValue=facevalue;
};

或者,您可以使用初始化列表:

Card::Card(Suit suit, Value facevalue) : suit(suit), faceValue(facevalue)
    { }
于 2012-09-19T03:56:10.270 回答
3

假设这个类看起来像:

class Card {
public:
    Card (Suit argSuit, Value argFaceValue);

private:
    Suit   m_Suit;
    Value  m_FaceValue;
};

构造函数看起来像这样。由于类的成员可用于从类创建的对象,因此您无需执行任何特殊操作即可访问它们。类的成员在范围内并且是可见的。您只需要确保函数的参数列表使用与类/对象成员不同的符号或名称。

Card::Card(Suit argSuit, Value argFaceValue)
{
    m_Suit = argSuit;
    m_FaceValue = argFaceValue;
}
于 2012-09-19T04:06:15.977 回答
2

这是对象调用

Card testcard(Suit hearts, Value six);

不,这是一个函数声明。自然地.,在函数名称上使用成员访问运算符 ( ) 是行不通的,函数有自己的类型,没有成员。

要声明一个自动变量(创建一个新的对象实例),不要重复参数类型。说啊:

Card testcard(hearts, six);
于 2012-09-19T04:11:27.353 回答
1

我认为您的一些命名约定给您带来了一些混乱。如上所述,您遇到了传递给构造函数的suitfacevalue参数的上下文问题。这意味着在构造方法的上下文中,西装实际上意味着作为参数传入的西装,而不是作为类 Card 的成员变量的西装。人们通常使用命名约定来帮助避免这种混淆,例如在类的每个数据成员前面放置一个m_,这样suit就会变成 m_suit。你可以使用任何你喜欢的东西,但是这样其他人的代码会马上知道 m_suit 是一个数据成员。

另一点是您可以并且可能应该在执行构造函数的代码之前初始化类的数据成员。这称为“初始化列表”,将按如下方式完成(假设您更改为上面的命名约定)。

Card::Card (Suit suit, Value facevalue)
 : m_suit (suit), m_facevalue (facevalue)
{
    // no code needs to go here
}

出于效率原因,养成这种习惯是个好主意。此外,在构造函数中使用this指针通常不是一个好主意。这并不违法,但会给你带来麻烦。

至于点运算符不起作用,从您的问题中不清楚您在哪里使用点运算符。如果您指的是上面的::语法,那并不是真正的运算符,它是 C++ 语法的一部分,表明您正在取消引用该类。如果您已将suitfacevalue数据成员声明为static ,该语法将起作用,但这不是您想要做的。

您提到您在多个头文件中声明 Card 类 - 这也很糟糕。

于 2012-09-19T04:22:42.677 回答