计算和组合ArrayList中的实例

时间:2017-05-25 00:58:08

标签: java object arraylist

我有以下类,它由一个ArrayList构造函数和一个方法组成,该方法用于根据指定的名称计算和组合对象的实例。方法getName()getCost在另一个类中提供。对象由String(名称)和double(cost)描述。

import java.util.*;
public class InventoryDemo
{
    public static void takeInventory(List<Product> products)
    {
        String[] names = new String[products.size()];
        for (int i = 0; i < products.size(); i ++)
        {
            String currentName = products.get(i).getName();
            names[i] = currentName;
            double totalCost = products.get(i).getCost();
            int quantity = 0;
            for (int i2 = 1; i2 < products.size() - 1; i2 ++)
            {
                if (products.get(i).getName() == products.get(i2).getName())
                {
                   quantity ++;
                   totalCost = totalCost + products.get(i2).getCost();
                }
            }
            System.out.print(currentName + ": Quantity = " + quantity);
            System.out.println(", Total Cost = " + totalCost);   
        }
    }

    public static void main(String []args)
    {       
        List<Product> products = new ArrayList<Product>();        
            Car car1 = new Car("Jaguar", 1000000.00);
            products.add(car1);
            Car car2 = new Car("Neon", 17000.00);
            products.add(car2);
            Tool saw1 = new Tool("JigSaw", 149.18);
            products.add(saw1);
            Car car3 = new Car("Jaguar", 110000.00);
            products.add(car3);
            Car car4 = new Car("Neon", 17500.00);
            products.add(car4);
            Car car5 = new Car("Neon", 17875.32);
            products.add(car5);
            Truck truck1 = new Truck("RAM", 35700.00);
            products.add(truck1);
            Tool saw2 = new Tool("CircularSaw", 200.00);
            products.add(saw2);
            Tool saw3 = new Tool("CircularSaw", 150.00);
            products.add(saw3);
        takeInventory(products);
    }
}

输出应该显示每个特定对象(基于名称)以及它们出现的数量和它们的组合成本。但是,它的输出大大不正确。有什么想法吗?

1 个答案:

答案 0 :(得分:0)

你的内部循环控制变量是不正确的,因为它始终从索引1开始,而它应该以{{1​​}}开始,与外部循环成比例,因此你的内部循环应该是:< / p>

i + 1

另一件事是你应该将字符串与.equals()进行比较。

for (int i2 = i + 1; i2 < products.size() - 1; i2++)