Guice вызвал метание UncaughtExceptionHandler - PullRequest
0 голосов
/ 05 июня 2018

Я хотел бы использовать Guice в своем приложении, но оно выдает следующее исключение, когда я хочу его запустить:

Exception in thread "main" 
Exception: com.google.common.util.concurrent.UncheckedExecutionException thrown from the UncaughtExceptionHandler in thread "main"

Когда я обертываю main() функцию с блоком try ... catch, я получаю фолловингstackTrace:

Exception in thread "main" com.google.common.util.concurrent.UncheckedExecutionException: java.lang.IllegalArgumentException
    at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2047)
    at com.google.common.cache.LocalCache.get(LocalCache.java:3869)
    at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3873)
    at com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4798)
    at com.google.common.cache.LocalCache$LocalLoadingCache.getUnchecked(LocalCache.java:4804)
    at com.google.inject.internal.util.StackTraceElements.forMember(StackTraceElements.java:71)
    at com.google.inject.internal.Messages.formatSource(Messages.java:241)
    at com.google.inject.internal.Messages.formatSource(Messages.java:220)
    at com.google.inject.internal.Messages.formatMessages(Messages.java:90)
    at com.google.inject.CreationException.getMessage(CreationException.java:50)
    at java.base/java.lang.Throwable.getLocalizedMessage(Throwable.java:396)
    at java.base/java.lang.Throwable.toString(Throwable.java:485)
    at java.base/java.lang.String.valueOf(String.java:2788)
    at java.base/java.io.PrintStream.println(PrintStream.java:897)
    at java.base/java.lang.Throwable$WrappedPrintStream.println(Throwable.java:752)
    at java.base/java.lang.Throwable.printStackTrace(Throwable.java:659)
    at java.base/java.lang.Throwable.printStackTrace(Throwable.java:648)
    at java.base/java.lang.Throwable.printStackTrace(Throwable.java:639)
    at com.github.blackjack.Main.main(Main.java:31)
Caused by: java.lang.IllegalArgumentException
    at com.google.inject.internal.asm.$ClassReader.<init>(ClassReader.java:160)
    at com.google.inject.internal.asm.$ClassReader.<init>(ClassReader.java:143)
    at com.google.inject.internal.asm.$ClassReader.<init>(ClassReader.java:418)
    at com.google.inject.internal.util.LineNumbers.<init>(LineNumbers.java:64)
    at com.google.inject.internal.util.StackTraceElements$1.load(StackTraceElements.java:49)
    at com.google.inject.internal.util.StackTraceElements$1.load(StackTraceElements.java:45)
    at com.google.common.cache.LocalCache$LoadingValueReference.loadFuture(LocalCache.java:3443)
    at com.google.common.cache.LocalCache$Segment.loadSync(LocalCache.java:2169)
    at com.google.common.cache.LocalCache$Segment.lockedGetOrLoad(LocalCache.java:2128)
    at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2041)
    ... 18 more

Из информации, которую я обнаружил, это исключение было вызвано методом, содержащим лямбда-определение, генерируемым методом Provides.Тем не менее это должно быть исправлено с Guice 4.0.Может кто знает как это исправить и может помочь?Заранее спасибо!

main() функция:

public static void main (String[] args){
    try{
        MainModule module = new MainModule();
        Injector injector = Guice.createInjector(module);

        GameFactory gameFactory = injector.getInstance(GameFactory.class);
        DeckFactory blackjackDeckFactory = injector.getInstance(BlackjackDeckCreator.class);
        PlayerFactory playerFactory = injector.getInstance(PlayerFactory.class);

        Player player = playerFactory.createPlayer("Paul");
        Player dealer = playerFactory.createPlayer("Dealer", true);

        Deck deck = blackjackDeckFactory.createDeck();

        Game game = gameFactory.createGame(player, dealer, deck);
        game.start();
    } catch (Exception e){
        e.printStackTrace(); // line 31
    }
}

1 Ответ

0 голосов
/ 06 июня 2018

Я использую Java 10, но также пробовал 8 и 9. Ничего не помогло.

Я думаю, что вы не использовали Java 8 или 9, потому что исключение выдается из ClassReader из-за использования версии 10 Java или более поздней.

https://gitlab.ow2.org/asm/asm/blob/f7f44a8e306dd2bd70f0db50194f6366938579c5/src/org/objectweb/asm/ClassReader.java#L160

Opcodes.V9 означает Java 9. Поэтому, пожалуйста, проверьте свою версию Java еще раз и запустите Java 9 или более раннюю версию.

...