Новая ошибка была зарегистрирована как JDK-8191655. Обходной путь: используйте нормальное лямбда-выражение вместо ссылки на метод.

из тестов ниже не работает. Почему?

public class SortedInterfacesTest {

private static final Logger log = LoggerFactory.getLogger(SortedInterfacesTest.class);

<T> void forAll(Consumer<T> consumer, T... values) { }

@Test
public void firstTest() {
    forAll(Shape::draw, new MyShape(), new Universal());
}

@Test
public void secondTest() {
    log.info("\njava.version {}", System.getProperty("java.version"));
    forAll(Picture::draw, new MyPicture(), new Universal());
}

interface Shape { void draw(); }
interface Marker { }
interface Picture { void draw(); }

class MyShape implements Marker, Shape { public void draw() {} }
class MyPicture implements Marker, Picture { public void draw() {} }
class Universal implements Marker, Picture, Shape { public void draw() {} }
}

В конце концов, пара Shape и MyShape - это симметричная пара Picture и MyPicture.

Второй тест завершается неудачно со следующей ошибкой (используйте cli: mvn.exe test):

-------------------------------------------------------
 T E S T S (Java.version: 1.8.0_102)
-------------------------------------------------------
Running SortedInterfacesTest
01:36:28.234 [main] INFO  SortedInterfacesTest - 
java.version 1.8.0_102
Tests run: 2, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 0.223 sec <<< FAILURE!
secondTest(SortedInterfacesTest)  Time elapsed: 0.009 sec  <<< ERROR!
java.lang.BootstrapMethodError: call site initialization exception
    at java.lang.invoke.CallSite.makeSite(Unknown Source)
    at java.lang.invoke.MethodHandleNatives.linkCallSiteImpl(Unknown Source)
    at java.lang.invoke.MethodHandleNatives.linkCallSite(Unknown Source)
    at SortedInterfacesTest.secondTest(SortedInterfacesTest.java:18)

Stacktrace на Java 9 + 181:

java.lang.BootstrapMethodError: call site initialization exception

    at java.base/java.lang.invoke.CallSite.makeSite(CallSite.java:385)
    at java.base/java.lang.invoke.MethodHandleNatives.linkCallSiteImpl(MethodHandleNatives.java:250)
    at java.base/java.lang.invoke.MethodHandleNatives.linkCallSite(MethodHandleNatives.java:240)
    at play.Play.firstTest(Play.java:12)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
    at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
Caused by: java.lang.invoke.LambdaConversionException: Invalid receiver type interface play.Play$Marker; not a subtype of implementation type interface play.Play$Shape
    at java.base/java.lang.invoke.AbstractValidatingLambdaMetafactory.validateMetafactoryArgs(AbstractValidatingLambdaMetafactory.java:254)
    at java.base/java.lang.invoke.LambdaMetafactory.metafactory(LambdaMetafactory.java:311)
    at java.base/java.lang.invoke.CallSite.makeSite(CallSite.java:332)
    ... 25 more
 Stuart Marks21 нояб. 2017 г., 17:54
Новая ошибка подана:JDK-8191655, Предыдущая ошибкаJDK-8058112 исправлена ​​только часть проблемы, но код здесь показывает случай, который остается нефиксированным. Извините за путаницу.
 Holger16 нояб. 2017 г., 23:14
Вы должны быть в состоянии обойти это с явными типамиthis.<Shape>forAll(Shape::draw, new MyShape(), new Universal()); а такжеthis.<Picture>forAll(Picture::draw, new MyPicture(), new Universal());.
 Andreas16 нояб. 2017 г., 22:38
Нет интерфейса с именемSortedInterfaces в вашем коде, так как компиляция может завершиться с этим именем?
 Holger16 нояб. 2017 г., 23:08
Кажется ты ударилЭта проблема, К несчастью,этот отчет об ошибке был закрыт как «исправлено». Таким образом, вы можете попытаться раздражать модуль Oracle, они снова открывают ошибку или понижаютэтот ответ что утверждает, что ошибка была исправлена; помогает ли это, я не знаю…
 Joe C16 нояб. 2017 г., 22:28
Я отклонил этот вопрос, потому что вы разместили здесь код, не уточняя, что с ним не так. Мы ожидаем увидеть, что вы ожидаете от кода, почему вы ожидаете, что он сделает это, что он на самом деле делает, и почему это неправильно. пожалуйстаредактировать Ваш вопрос, чтобы включить эту информацию, а затем я рассмотрю возможность отказа от моего понижения. Видеть:Как создать минимальный, полный и проверяемый пример

Ответы на вопрос(1)

используйте нормальное лямбда-выражение вместо ссылки на метод.

Ваш ответ на вопрос