gpt4 book ai didi

java.lang.IncompatibleClassChangeError : Implementing class 错误

转载 作者:行者123 更新时间:2023-11-29 06:36:18 25 4
gpt4 key购买 nike

我正在尝试实现一个调度程序来安排 3 个作业,但仅在第一个作业实现时出现不兼容的类更改错误..

错误在线,

JobDetail jobA = JobBuilder.newJob(JobA.class)
.withIdentity(jobKeyA).build();

有什么帮助吗??

完整代码如下..

import org.quartz.CronScheduleBuilder;
import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.JobKey;
import org.quartz.Scheduler;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;

public class Scheduler1 {
public static void main( String[] args ) throws Exception
{

JobKey jobKeyA = new JobKey("jobA", "group1");
JobDetail jobA = JobBuilder.newJob(JobA.class)
.withIdentity(jobKeyA).build();

JobKey jobKeyB = new JobKey("jobB", "group1");
JobDetail jobB = JobBuilder.newJob(JobB.class)
.withIdentity(jobKeyB).build();

JobKey jobKeyC = new JobKey("jobC", "group1");
JobDetail jobC = JobBuilder.newJob(JobC.class)
.withIdentity(jobKeyC).build();


Trigger trigger1 = TriggerBuilder
.newTrigger()
.withIdentity("dummyTriggerName1", "group1")
.withSchedule(
CronScheduleBuilder.cronSchedule("0/5 * * * * ?"))
.build();

Trigger trigger2 = TriggerBuilder
.newTrigger()
.withIdentity("dummyTriggerName2", "group1")
.withSchedule(
CronScheduleBuilder.cronSchedule("0/5 * * * * ?"))
.build();

Trigger trigger3 = TriggerBuilder
.newTrigger()
.withIdentity("dummyTriggerName3", "group1")
.withSchedule(
CronScheduleBuilder.cronSchedule("0/5 * * * * ?"))
.build();

Scheduler scheduler = new StdSchedulerFactory().getScheduler();

scheduler.start();
scheduler.scheduleJob(jobA, trigger1);
scheduler.scheduleJob(jobB, trigger2);
scheduler.scheduleJob(jobC, trigger3);

}
}

我有三个类 jobA、jobB、jobC,但是当我将它们添加到上面的调度程序时,我得到如下错误,

线程“main”中的异常 java.lang.IncompatibleClassChangeError:实现类 在 java.lang.ClassLoader.defineClass1( native 方法) 在 java.lang.ClassLoader.defineClass(ClassLoader.java:788) 在 java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) 在 java.net.URLClassLoader.defineClass(URLClassLoader.java:447) 在 java.net.URLClassLoader.access$100(URLClassLoader.java:71) 在 java.net.URLClassLoader$1.run(URLClassLoader.java:361) 在 java.net.URLClassLoader$1.run(URLClassLoader.java:355) 在 java.security.AccessController.doPrivileged( native 方法) 在 java.net.URLClassLoader.findClass(URLClassLoader.java:354) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:424) 在 sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:357) 在 Scheduler1.main(Scheduler1.java:15)

最佳答案

我也遇到过这个问题。在深入研究核心 Java 代码之后,我们发现这个简单的应用程序每次都会产生问题:

public static void main(String[] args) {
System.out.println(AssertionBuilderRegistry.class);
System.out.println(AssertionBuilderRegistryImpl.class);
}

通过在调试器中放置一个 Exception 断点并沿着调用堆栈向上移动直到我们得到一些命名的嫌疑人,这些类被确定为违规者。

mvn dependency:tree

产生这个片段:

\- org.apache.cxf:cxf-bundle-minimal:jar:2.4.10:compile
[INFO] | | +- org.apache.ws.xmlschema:xmlschema-core:jar:2.0.3:compile
[INFO] | | +- org.apache.geronimo.specs:geronimo-stax-api_1.0_spec:jar:1.0.1:compile
[INFO] | | +- org.apache.geronimo.specs:geronimo-annotation_1.0_spec:jar:1.1.1:compile
[INFO] | | +- javax.xml.bind:jaxb-api:jar:2.1:compile
[INFO] | | +- org.apache.neethi:neethi:jar:2.0.4:compile

所以,基本上,

AssertionBuilderRegistryImpl

必须实现/扩展

AssertionBuilderRegistry

那么,让我们来看看 CXF 版本的 AssertionBuilderRegistryImpl

public class AssertionBuilderRegistryImpl extends AssertionBuilderFactoryImpl implements
AssertionBuilderRegistry, BusExtension {

现在是 AssertionBuilderRegistry

public interface AssertionBuilderRegistry extends AssertionBuilderFactory { // intellij highlights red here on the extends 

那么,让我们看看 AssertionBuilderFactory

public class AssertionBuilderFactory

好吧,我们有一个类实现和接口(interface),那个接口(interface)扩展了一个类?!

等等,这是 maven 指出的正确版本。那么,cxf minimal 依赖于与之不兼容的东西?!

让我们看一下 cxf-minimal 的 pom(片段):

<dependency>
<groupId>org.apache.neethi</groupId>
<artifactId>neethi</artifactId>
<version>3.0.2</version>
<scope>compile</scope>
</dependency>

好吧,WTF?! Maven 依赖项表示它需要 2.0.4(这显然是不兼容的)而这个工件的 pom 表示它需要 3.0.2

所以,解决方案:

    <dependency>
<groupId>org.apache.neethi</groupId>
<artifactId>neethi</artifactId>
<version>3.0.2</version>
<scope>compile</scope>
</dependency>

在我们的主项目 POM 中显式声明依赖。

错误。在行家。最新版本的 maven (3.2.1) 也是如此。

关于java.lang.IncompatibleClassChangeError : Implementing class 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20137309/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com