微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

相同的linkedlist代码groovy和java之间的不同行为,为什么

我在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方法,它才会有所不同.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐