0

有効なトッピングのループを正常に繰り返すことができるようになったので、プログラムにトッピングに0.75の追加料金を追加することはできません。なぜそうなのか教えていただければと思いました。プログラム全体が一番下にあります。私に関係する2つの部分は

public class TestPizza
{
  public static void main(String args[])
  {
    int x;
    String top[] = {"Mushrooms", "Onions", ""};
    Pizza one = new Pizza();
    Pizza two = new Pizza();
    Pizza three = new Pizza();

one.setSize(12);
one.addTopping(top);
one.showValues();

  }
}

// setPrice() assigns a price to the pie
public void addTopping(String programToppings[])
{
  for(int x = 0; x < 3; x++)
  {
    toppings[x] = programToppings[x];
  }
  for(int x = 0; x < 3; x++)
  {
    toppings[x] = toppings[x].toLowerCase();
  }
  for(int x = 0; x < 3; x++)
  {
    for(int xx = 0; xx < 6; xx++)
    {
      if(toppings[x].equals(validToppings[xx]))
      {price += 0.75;}
    }
  }
}

.equalsメソッドが機能せず、変更の奇数合計を最終価格に割り当てている理由がわかりません...

// This custom class is used to create Pie objects
// It stores the data about the Pie in four variables:
// size, price, type and baked
// It lets the program that creates the Pie object set these values using four methods:
// setSize, setPrice, setType and bake

public class Pizza
{

  // Declare four variables that can store the values for each pie
  // Each Pie object will have their own, separate copy of these variables 12.
    private int size;
    private double price;
    private boolean baked;
    private int x;
    private int xx;
    private String validToppings[] = new String[6];
    private String toppings[] = new String[3];


    // The "constructor" method is called when a new pie
    // object is first created. We use it to set "default" values.
    // Our typical pie is 10 inches, costs $8 and is not baked yet
    // We don't yet know what the pie filling will be
    Pizza()
    {
      size = 8;
      price = 10.0;
      baked = false;
      String validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};
      String toppings[] = new String[3];
    }

    // showValues() is a void method that displays the values of the
    // current Pie
    public void showValues()
    {
      System.out.println("Pie Size: " + size);
      for(int x = 0; x < 3; x++) {System.out.println("With " + toppings[x]);};
      System.out.println("Price of Pie: $" + price);
    }

    // getSize() returns the size of the pie
    public int getSize()
    {
      return size;
    }
    // getPrice() returns the price of the pie
    public double getPrice()
    {
      return price;
    }
    // baked() returns whether or not the pie is baked
    public boolean getBaked()
    {
      return baked;
    }
    // setSize() assigns a size to the pie
    public void setSize(int thisSize)
    {
      size = thisSize;
      switch(size)
      {
        case 8: price = 10.00; break;
        case 12: price = 14.00; break;
        case 16: price = 18.00; break;
        default: System.out.println("Error in Pizza class: Attempt to set invalid Pizza size."); break;
      }
    }

    // setPrice() assigns a price to the pie
    public void addTopping(String programToppings[])
    {
      for(int x = 0; x < 3; x++)
      {
        toppings[x] = programToppings[x];
      }
      for(int x = 0; x < 3; x++)
      {
        toppings[x] = toppings[x].toLowerCase();
      }
      for(int x = 0; x < 3; x++)
      {
        for(int xx = 0; xx < 6; xx++)
        {
          if(toppings[x].equals(validToppings[xx]))
          {price += 0.75;}
        }
      }
    }

  public void bake()
  {
    baked = true;
  };

}
4

3 に答える 3

4

PizzaのvalidTopicsインスタンス配列がいっぱいになることはありません。交換

String validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};

Pizzaコンストラクタで:

this.validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};

さらに、コードにはいくつかの奇妙なことがあります。

  • addToppingトッピングの反復に関してはかなり非効率的です
  • addToppingループで(IMO)マジックナンバーを使用for=> 3
  • 配列をPizza2回初期化します
  • さまざまなトッピングを初期化して検証する方法は混乱を招きます
于 2012-04-23T06:42:21.037 に答える
0

配列validToppingsは空です。各文字列をnullと比較しています。

あなたはPizzaこの方法のメンバーを宣言しています:;

private String validToppings[] = new String[6];
private String toppings[] = new String[3];

この方法でコンストラクターに値を割り当てようとしています

String validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};
String toppings[] = new String[3];

しかし、コンストラクターからの上記のコードはすべて、コンストラクターの実行が完了した後に忘れられる新しいローカル変数を作成することです。

修正は、メンバーに値を割り当てることです。たとえば、考えられる適切な解決策の1つは次のとおりです。

  • 次のようにメンバーを宣言します。 String[] validToppings;
  • そして、次のようにコンストラクターに値を割り当てます。 validToppings = {"mushroooms", ... };

設計の観点から(初心者かもしれませんが、それでも言及する価値があります)、列挙を使用する必要があります(文字列の比較、タイプミスの作成などを節約できます)。

于 2012-04-23T06:47:32.037 に答える
0
 Pizza()
{
  size = 8;
  price = 10.0;
  baked = false;
  String validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};
  String toppings[] = new String[3];
}

ここ、

String validToppings[] = {"mushrooms", "pepperonis", "onions", "mushroom", "pepperoni", "onion"};

はコンストラクターに対してローカルであり、グローバルな'validToppings[]'に接続されていません。それに見る。

于 2012-04-23T07:09:15.533 に答える