0

タイトルが示すように、私は列挙型を試していますが、完全に間違った出力を得ています。カードのスーツとランクを取得する代わりに、2 つの null 値を取得しています。

誰かが私を正しい方向に向けますか?

カードクラス

public class Card {



    private Suit suit;
    private Rank rank;



    public Card (Suit suit, Rank rank) {

    }

    public Suit getSuit(){
        return suit;
    }

      public void setSuit(Suit suit)
    {
    this.suit = suit;
    }

    public Rank getRankValue()
    {
    return rank;
    }

    public void setRankValue(Rank rank)
    {
    this.rank = rank;
    }


    @Override
    public String toString ( ) { return ( rank + " of " + suit ); }

    }

ハンドクラス

public class Hand {

private Card theCards[ ];
private int numCards;
private static final int max = 5;

public Hand ( )
{
 theCards = new Card [max];
 numCards = 0;
}
public void addCard( Card aCard ) 
{ 
     if (numCards < max) theCards[numCards++] = aCard; 
}
@Override
public String toString ( ) 
{
   String s = ""; 
   for (int i = 0; i < numCards; ++i)  { 
    s += "\n" + theCards[i]; 
   }
   return s;
}
}

ランククラス

public enum Rank {

ACE(1),
TWO(2),
THREE(3),
FOUR(4),
FIVE(5),
SIX(6),
SEVEN(7),
EIGHT(8),
NINE(9),
TEN(10),
JACK(10),
QUEEN(10),
KING(10);

private int rank;

private Rank (int value)

{
 this.rank = value;
}

public int getRankValue() {

return rank;
}
}

スーツクラス

public enum Suit {

HEARTS , SPADES , CLUBS , DIAMONDS 
}

そして、カードを作成してtoStringを呼び出すための私のクラス。

public class HandDriver {

public static void main( String[] args ){ 

Card c1 = new Card(Suit.valueOf("HEARTS"),Rank.valueOf("TEN"));
System.out.print (c1.toString());
}
}
4

1 に答える 1

5
public Card (Suit suit, Rank rank) {

}

問題は列挙型ではありませんが、コンストラクターでは文字通り何もしていません。Suitパラメータとしてandを取得Rankしますが、それらをローカル変数に保存しません。以下のコードのように、ローカル インスタンス変数の値に、コンストラクターを介して取得したパラメーターを割り当てる必要があります。

public Card (Suit suit, Rank rank) {
   this suit = suit;
   this.rank = rank;
}
于 2013-11-08T16:13:12.463 に答える