Как я могу исправить ошибку NoSuchMethodError из библиотеки Time4J?

У меня трепещет NoSuchMethodError в этой строке моего кода:

    private CalendarPicker<PersianCalendar> calendarPicker = CalendarPicker.persianWithSystemDefaults();

Он отлично работает, когда я запускаю проект в intellij idea, но выходной файл jar не запускается. Я экспортировал проект в eclipse и получил эту ошибку в eclipse.

Я использовал эти библиотеки:

1 - time4j-core-4.38

2 - time4j-ui-5.5

3 - time4j-calendar-4.38.jar

4 - time4j-base-5.5.jar

Полный текст ошибки:

Exception in Application start method
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:389)
    at com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:328)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at sun.launcher.LauncherHelper$FXHelper.main(Unknown Source)
Caused by: java.lang.RuntimeException: Exception in Application start method
    at com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:917)
    at com.sun.javafx.application.LauncherImpl.lambda$launchApplication$159(LauncherImpl.java:182)
    at java.lang.Thread.run(Unknown Source)
Caused by: java.util.ServiceConfigurationError: net.time4j.scale.LeapSecondProvider: Provider net.time4j.scale.spi.DefaultLeapSecondProviderSPI could not be instantiated
    at java.util.ServiceLoader.fail(Unknown Source)
    at java.util.ServiceLoader.access$100(Unknown Source)
    at java.util.ServiceLoader$LazyIterator.nextService(Unknown Source)
    at java.util.ServiceLoader$LazyIterator.next(Unknown Source)
    at java.util.ServiceLoader$1.next(Unknown Source)
    at net.time4j.base.ResourceLoader$StdResourceLoader.services(ResourceLoader.java:463)
    at net.time4j.scale.LeapSeconds.<init>(LeapSeconds.java:201)
    at net.time4j.scale.LeapSeconds.<clinit>(LeapSeconds.java:179)
    at net.time4j.SystemClock.calibrate(SystemClock.java:474)
    at net.time4j.SystemClock.<clinit>(SystemClock.java:95)
    at net.time4j.ui.javafx.CalendarPicker.lambda$persianWithSystemDefaults$15(CalendarPicker.java:761)
    at net.time4j.ui.javafx.CalendarControl.<init>(CalendarControl.java:82)
    at net.time4j.ui.javafx.CalendarPicker.<init>(CalendarPicker.java:178)
    at net.time4j.ui.javafx.CalendarPicker.create(CalendarPicker.java:1110)
    at net.time4j.ui.javafx.CalendarPicker.persian(CalendarPicker.java:785)
    at net.time4j.ui.javafx.CalendarPicker.persianWithSystemDefaults(CalendarPicker.java:759)
    at HomeScreenController.<init>(HomeScreenController.java:71)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at java.lang.Class.newInstance(Unknown Source)
    at sun.reflect.misc.ReflectUtil.newInstance(Unknown Source)
    at javafx.fxml.FXMLLoader$ValueElement.processAttribute(FXMLLoader.java:927)
    at javafx.fxml.FXMLLoader$InstanceDeclarationElement.processAttribute(FXMLLoader.java:971)
    at javafx.fxml.FXMLLoader$Element.processStartElement(FXMLLoader.java:220)
    at javafx.fxml.FXMLLoader$ValueElement.processStartElement(FXMLLoader.java:744)
    at javafx.fxml.FXMLLoader.processStartElement(FXMLLoader.java:2707)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2527)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2441)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3214)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3175)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3148)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3124)
    at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3104)
    at javafx.fxml.FXMLLoader.load(FXMLLoader.java:3097)
    at Main.start(Main.java:39)
    at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$166(LauncherImpl.java:863)
    at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$179(PlatformImpl.java:326)
    at com.sun.javafx.application.PlatformImpl.lambda$null$177(PlatformImpl.java:295)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.application.PlatformImpl.lambda$runLater$178(PlatformImpl.java:294)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$152(WinApplication.java:177)
    ... 1 more
Caused by: java.lang.NoSuchMethodError: net.time4j.PlainDate.localFormatter(Ljava/lang/String;Lnet/time4j/format/ChronoPattern;)Lnet/time4j/format/TemporalFormatter;
    at net.time4j.scale.spi.DefaultLeapSecondProviderSPI.<init>(DefaultLeapSecondProviderSPI.java:77)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at java.lang.Class.newInstance(Unknown Source)
    ... 44 more
Exception running application Main

2 ответа

Решение

А NoSuchMethodError обычно означает разницу в зависимости между средой времени компиляции и средой выполнения.

Фактически, вероятно, что у вас есть: 1. несколько разных версий net.time4j JAR в вашем пути к классам 2. другой net.time4j JAR в пути к классам среды выполнения, чем использовался во время компиляции.

Поскольку иерархия вызовов, кажется, предлагает net.time4j сам вызывает метод, о котором он не знает, я подозреваю, что в пути к классам есть несколько версий JAR.

Это похоже на JAR, о которых вы говорите. Вы смешиваете версию4.38 и версия 5.5. Вам следует придерживаться одной версии всех библиотек в пакете, так как они, скорее всего, будут разработаны для совместной работы.

Вы, вероятно, немного запутались, потому что кажется, что Time4J изменил упаковку между версиями 4.x и 5.x и time4j-core вероятно теперь назван time4j-base

На веб-сайте Time4J есть учебная страница, которая, кажется, предлагает вам просто удалить существующие зависимости отtime4-core а также time4j-calendar.

У меня была такая же проблема с сочетанием разных time4j - версий из-за разных источников, найденных в Интернете.

Итак, это НЕ РАБОТАЕТ - POM.XML - Конфигурация, приводящая к проблеме:

<!-- https://mvnrepository.com/artifact/net.time4j/time4j-core -->
       <dependency>
          <groupId>net.time4j</groupId>
          <artifactId>time4j-parent</artifactId>
          <version>5.5</version>
          <type>pom</type>
      </dependency>
        <dependency>
           <groupId>net.time4j</groupId>
           <artifactId>time4j-core</artifactId>
           <version>4.38</version>
       </dependency>      
<!-- https://mvnrepository.com/artifact/net.time4j/time4j-base -->
       <dependency>
           <groupId>net.time4j</groupId>
           <artifactId>time4j-base</artifactId>
           <version>5.5</version>
       </dependency>
       <dependency>
           <groupId>net.time4j</groupId>
           <artifactId>time4j-i18n</artifactId>
           <version>4.38</version>
       </dependency>
    </dependencies>

РЕШЕНИЕ: Обновление MAVEN - Репозиторий. Maven по-прежнему использовал 4.38, хотя я перешел на 5.5 - была необходима очистка (очистка) репозитория.

<!-- https://mvnrepository.com/artifact/net.time4j/time4j-base -->
       <dependency>
           <groupId>net.time4j</groupId>
           <artifactId>time4j-base</artifactId>
           <version>5.5</version>
       </dependency>
    </dependencies>


    <build>
      <pluginManagement>
        <plugins>
           <plugin>
             <groupId>org.apache.maven.plugins</groupId>
             <artifactId>maven-jar-plugin</artifactId>
             <configuration>
               <archive>
                 <manifest>
                    <addClasspath>true</addClasspath>
                    <mainClass>fully.qualified.MainClass</mainClass>
                 </manifest>
               </archive>
             </configuration>
           </plugin>
           <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-dependency-plugin</artifactId>
              <version>3.1.1</version>
              <executions>
                 <execution>
                    <id>build-classpath</id>
                    <phase>generate-sources</phase>
                    <goals>
                       <goal>build-classpath</goal>
                       <goal>purge-local-repository</goal>
                     </goals>
                   <configuration>
                    <!-- configure the plugin here -->
                   </configuration>
                 </execution>
              </executions>
           </plugin>           
           <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
       </pluginManagement>
      <finalName>${project.artifactId}</finalName>
    </build>

Теперь это работает как шарм.

Другие вопросы по тегам