这是 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");
不应该抛出这个异常吗?