我在groovy中使用链表作为堆栈
正如doc所说,pop()从第一个开始就拿elm
Stack Method Equivalent Deque Method
push(e) addFirst(e)
pop() removeFirst()
所以一个链表[1,2,3]应该pop()1 2 3
它在Java中,但不是在groovy中.为什么?
测试如下
A.java
import java.util.*;
public class A{
public static void main(String[] args){
String[] x = "1/2/3/".split("/");
LinkedList <String> stack = new LinkedList<String>(Arrays.asList(x));
System.out.println(stack.pop());
}
}
编译并运行
$javac A.java
$java A
1
在groovy中奔跑
$ln -s A.java A.groovy
$groovy A.groovy
3
这是我的java和groovy版本
$java -version
java version "1.6.0_51"
Java(TM) SE Runtime Environment (build 1.6.0_51-b11-457-11M4509)
Java HotSpot(TM) 64-Bit Server VM (build 20.51-b01-457, mixed mode)
$groovy -version
Groovy Version: 2.1.5 JVM: 1.6.0_51 Vendor: Apple Inc. OS: Mac OS X
解决方法:
这似乎是groovy的“特征”. Default Groovy Methods被描述为此类定义了新的groovy方法,这些方法出现在Groovy环境中的普通JDK类中.
DefaultGroovyMethods提供的方法之一是pop(),其描述为:从List中删除最后一项.因此看起来Groovy正在编织一个不同的pop()实现,它与LinkedList默认提供的内容相冲突.
几年前针对GDM提交的A bug report最好地描述了它,并提供了一些额外的评论:LinkedList似乎实现了List和一个pop / push方法,因此classes方法不应该被DGM方法遮蔽.只有我们在DGM中有一个LinkedList #pop / push方法,它才会有所不同.