【问题标题】:Debugger says I'm getting a null pointer exception. Why?调试器说我得到一个空指针异常。为什么?
【发布时间】:2014-05-12 18:21:29
【问题描述】:

我正在编写一个以特定方式对对象进行排序的简单程序。但是,运行时在

之后停止
hardware[i].setItemID(itemID[i]); 

如 Eclipse 的调试器所示。完整代码如下:

public class TestItem
{
    public static void main(String [] args)
    {
        Item[] hardware = new Item[6];
        String[] itemID = {"1011", "1034", "1101", "1600", "1500", "1201"};
        String[] itemName = {"Air Filters", "Door Knobs", "Hammers", "Levels", "Ceiling Fans", "Wrench Sets"}; 
    int[] inStore = {200, 60, 90, 80, 100, 55};
    double[] price = {10.5, 21.5, 9.99, 19.99, 59, 80}; //80 dollars for a wrench set? Really? Shoulda gone to Sears... 
    for(int i = 0; i <= 5; i++)
    {
        hardware[i].setItemID(itemID[i]);
        hardware[i].setItemName(itemName[i]);
        hardware[i].setInStore(inStore[i]);
        hardware[i].setPrice(price[i]);
    }
    printInventory(hardware);
sortID(hardware);
sortInStore(hardware);
sortName(hardware);
sortPrice(hardware);

}
public static void printInventory(Item[] items)
{
for(int i = 0; i < items.length; i++)
 {
    System.out.println(items[i].toString());
 }
}
public static void sortName(Item[] items)
{
for(int i = 1; i < items.length; i++)
    {
    int j = i;
    int compareMeForWhile = items[i].getItemName().compareTo(items[i-1].getItemName());

    while(j>0 && compareMeForWhile == 1)
        {
        compareMeForWhile = items[i].getItemName().compareTo(items[i-1].getItemName());
        String temp1 = items[i].getItemName();
        String temp2 = items[i-1].getItemName();
        items[i].setItemName(temp2);
        items[i-1].setItemName(temp1);
        j--;
        }
    }
for(int i = 0; i < items.length-1; i++)
    System.out.println(items[i].toString());
}
public static void sortID(Item[] items)
{
for(int i = 1; i < items.length; i++)
    {
    int j = i;          
    while(j>0 && items[i].getItemID().compareTo(items[i-1].getItemID()) < 0)
        {

        String temp1 = items[i].getItemID();
        String temp2 = items[i-1].getItemID();
        items[i].setItemID(temp2);
        items[i-1].setItemID(temp1);
        j--;
        }
    }
for(int i = 0; i < items.length-1; i++)
    System.out.println(items[i].toString());
}
public static void sortInStore(Item[] items)
{
for(int i = 1; i < items.length; i++)
    {
    int j = i;          
    while(j>0 && items[i].getInStore() > items[i-1].getInStore())
        {

        int temp1 = items[i].getInStore();
        int temp2 = items[i-1].getInStore();
        items[i].setInStore(temp2);
        items[i-1].setInStore(temp1);
        j--;
        }
    }
    for(int i = 0; i < items.length-1; i++)
        System.out.println(items[i].toString());
}
public static void sortPrice(Item[] items)
{
for(int i = 1; i < items.length; i++)
    {
    int j = i;          
    while(j>0 && items[i].getPrice() > items[i-1].getPrice())
        {

        double temp1 = items[i].getPrice();
        double temp2 = items[i-1].getPrice();
        items[i].setPrice(temp2);
        items[i-1].setPrice(temp1);
        j--;
        }
    }
for(int i = 0; i < items.length-1; i++)
    System.out.println(items[i].toString());
}

//Sort ID, Name, In store, and price. Print results.



//for i ↠1 to length(A)
//j ↠i
//while j > 0 and A[j-1] > A[j]
//    swap A[j] and A[j-1]
//    j ↠j - 1
}

【问题讨论】:

    标签: java arrays exception object


    【解决方案1】:
    Item[] hardware = new Item[6];
    

    通过这个你初始化了一个包含 6 个引用的数组,所有引用仍然是 null 你需要初始化每个元素,比如

    hardware[i] = new Item();
    

    在访问之前

    【讨论】:

      【解决方案2】:

      Item[] hardware = new Item[6]; 中的每个 Item 都是 null,这就是您获得 NPE 的原因。

      在访问之前使用新的Item 对象初始化每个数组元素。

      【讨论】:

        【解决方案3】:

        您为数组 Item[] 保留了内存,但没有为其中的每个元素保留内存。

        【讨论】:

          【解决方案4】:

          初始化一个数组 (Item[] hardware = new Item[6];) 只是创建一个具有nulls 的指定大小的数组。如果你要设置这些项目的属性,你必须先初始化它们:

          for(int i = 0; i <= 5; i++)
          {
              hardware[i] = new Item(); // Missing from your snippet
              hardware[i].setItemID(itemID[i]);
              hardware[i].setItemName(itemName[i]);
              hardware[i].setInStore(inStore[i]);
              hardware[i].setPrice(price[i]);
          }
          

          【讨论】:

            【解决方案5】:

            hardware[] 中的所有元素都初始化为 null。您需要将对象的引用存储在您的案例 Item() 中,然后使用 setter 方法。

               for(int i = 0; i <= 5; i++)
                {
                    hardware[i]=new Item();
                    hardware[i].setItemID(itemID[i]);
                    hardware[i].setItemName(itemName[i]);
                    hardware[i].setInStore(inStore[i]);
                    hardware[i].setPrice(price[i]);
            }
            

            【讨论】: