0

クラス Card のネストされた列挙型の接尾辞インクリメント演算子をオーバーロードする方法を理解するのに苦労しています。さらに、このクラスでコピーの割り当てがうまくいかないこともあります。「operator++ は 1 つまたはゼロの引数を取る必要があります」というエラーが表示されます。次に、割り当てを提供しようとすると、

no match for operator= in ((deck*)->this)->Deck::deckArr = operator new 

class Card {
  public:
    enum Suit {
      SPADES,
      HEARTS,
      CLUBS,
      DIAMONDS
    };

    enum Spot {
      DEUCE,
      THREE,
      FOUR,
      FIVE,
      SIX,
      SEVEN,
      EIGHT,
      NINE,
      TEN,
      JACK,
      QUEEN,
      KING,
      ACE
   };

   Card();
   Card(Card&);
   Card(Suit&, Spot&);
   ~Card();

   Suit& operator++(Suit&,int);
   Spot& operator++(Spot&,int);
   Card& operator=(const Card&);

 private:
   Spot _spot;
   Suit _suit;
};

Card::Suit& Card::operator++(Card::Suit &s, int) {Card::Suit oldsuit = s;
                                            s = (Card::Suit)(s+1);
                                            return oldsuit;}
Card::Spot& Card::operator++(Card::Spot &sp, int){Card::Spot oldspot = sp;
                                            sp = (Card::Spot)(sp+1);
                                            return oldspot;}
Card& Card::operator=(const Card &c){_spot = c._spot; _suit = c._suit; return *this;}


#include "card.h"

class Deck {
 public:
    Deck();
    Deck(Deck&);
    ~Deck();

    void createDeck();
    void shuffleDeck(int);
 private:
    static const int DECK_SIZE = 52;
    Card deckArr[DECK_SIZE];
};

void Deck::createDeck(){
    int x = 0;
    for(Card::Suit s = Card::SPADES; s <= Card::HEARTS; s++){
        for(Card::Spot n = Card::DEUCE; n <= Card::ACE; n++, x++){
             deckArr[x] = new Card(s, n);
        }
    }
}
4

2 に答える 2

1

オーバーロードするには 2 つの方法がありますoperator++

Card::Suit operator++(int){ } //would be suit++

Card::Suit& operator++() { } //would be ++suit

operator++ダミー パラメータ (通常はint)を除いて、には何も渡してはなりません。通常reference、後置で a を返しません。

詳細については、こちらを参照してください。

于 2013-08-13T14:09:21.837 に答える