加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

为什么Oracle Java编译器不能在这里推断出界限,但Eclipse可以?

发布时间:2020-12-12 16:25:25 所属栏目:百科 来源:网络整理
导读:我有这个(貌似)无辜的代码(在这里简化为这个JUnit测试用例): import static org.hamcrest.Matchers.instanceOf;import static org.junit.Assert.assertThat;import java.util.Collections;import java.util.HashMap;import java.util.Map;import java.util.
我有这个(貌似)无辜的代码(在这里简化为这个JUnit测试用例):
import static org.hamcrest.Matchers.instanceOf;
import static org.junit.Assert.assertThat;

import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.function.Supplier;

import org.junit.Test;

public class GenericsTest {
    private static boolean doFail;

    private static Map<String,Number> createMap() {
        if (doFail) {
            throw new IllegalArgumentException();
        }
        return new HashMap<>();
    }

    public static <T> T get(final Callable<T> _valueCreator,final Supplier<T> _errorValue) {
        try {
            return _valueCreator.call();
        } catch (final Exception e) {
            return _errorValue.get();
        }
    }

    public static Map<String,Number> getCachedMap() {
        return get(GenericsTest::createMap,Collections::emptyMap);
    }

    @Test
    public void testSuccess() {
        doFail = false;
        assertThat(getCachedMap(),instanceOf(HashMap.class));
    }

    @Test
    public void testFail() {
        doFail = true;
        assertThat(getCachedMap(),instanceOf(Collections.EMPTY_MAP.getClass()));
    }
}

问题在于行返回get(GenericsTest :: createMap,Collections :: emptyMap):Eclipse编译器在这里看不到问题(我也是如此),愉快地编译并运行测试并成功.

但是,当我在命令行(Maven 3,在这种情况下为Oracle JDK8,但也不能直接使用javac)上编译它时,会抛出编译错误:

.../GenericsTest.java:[23,19] incompatible types: inferred type does not conform to upper bound(s)
inferred: java.util.Map<? extends java.lang.Object,? extends java.lang.Object>
upper bound(s): java.util.Map<java.lang.String,java.lang.Number>,java.lang.Object

我认为,从返回类型(Map< String,Number>)以及createMap的签名(相同),应该可以推断出所需的类型 – 实际上似乎Eclipse编译器似乎是能够做到这一点.但是,JDK编译器仅推断Map< Object,Object>因此失败了.

这是JDK错误还是Eclipse编译器错误或其他什么?

这看起来像一个bug.我会处理它,并且一旦我们获得有关为什么会发生这种情况的更多信息,可能会添加更好的答案.我已提交此错误条目 JDK-8043926以跟踪它.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读