0

这是 Stack 的可变实现:

class LinkedStackGeneric {

  var first : NodeGeneric = _

  def isEmpty : Boolean  = {
    first == null
  }

  def push(itemName : Any) = {
    val oldFirst = first
    first = new NodeGeneric(itemName , oldFirst)
  } 

  def pop = {
    first = first.next

    first.itemName

  }

}

      class NodeGeneric(val itemName : Any , val next : NodeGeneric) {}

   println("*********** testing LinkedStackGeneric *****************")

       val generic = new LinkedStackGeneric
       generic.push("test")
       generic.push("here");
       println(generic.isEmpty)
       println(generic.pop);
       println(generic.isEmpty)
       println(generic.pop);
       println(generic.isEmpty)

当我运行此代码时,它会产生以下内容:

*********** testing LinkedStackGeneric *****************
false
test
false
Exception in thread "main" java.lang.NullPointerException
    at LinkedStackGeneric.pop(LinkedStackGeneric.scala:19)
    at StacksAndQueuesTest$.main(StacksAndQueuesTest.scala:37)
    at StacksAndQueuesTest.main(StacksAndQueuesTest.scala)

这是导致错误的行:

println(generic.pop);

是什么导致了这个异常,我没有正确地将项目推入堆栈吗?因为我推了两个项目:

   generic.push("test")
   generic.push("here");

不应该抛出这个异常吗?

4

2 回答 2

1

修正你的pop方法。您的执行顺序导致了问题...

 def pop = {
    val ret  = first.itemName
    first = first.next
    ret
  }
于 2013-04-18T19:35:02.043 回答
0

对 pop 的第二次调用首先设置为null,然后您尝试itemName在该空值上调用该方法

于 2013-04-18T19:39:52.867 回答