我有几十节课看起来像:
@Repository("jobProcessingDao")
@Transactional(readOnly = true)
public class JobProcessingDaoImpl extends BaseDaoImpl implements JobProcessingDao {
/*implementation interface methods*/
}
异常只发生在这一个(并且只有这一个是由cglib生成的)。
实际上,为什么spring使用cglib代理而不是JDK?我的类实现了interface,我相信我没有为ProxyFactoryBean的proxyInterfaces设置任何值。
behemoth@Anechka ~ $ javap -c xf.class
Compiled from "<generated>"
public class package_name.dataaccesscomponent.impl.JobProcessingDaoImpl$$EnhancerByCGLIB$$f8ed98b3 extends package_name.dataaccesscomponent.impl.JobProcessingDaoImpl implements org.springframework.context.annotation.ConfigurationClassEnhancer$EnhancedConfiguration {
static void CGLIB$STATICHOOK2();
Code:
0: new #22 // class java/lang/ThreadLocal
3: dup
4: invokespecial #25 // Method java/lang/ThreadLocal."<init>":()V
7: putstatic #27 // Field CGLIB$THREAD_CALLBACKS:Ljava/lang/ThreadLocal;
10: iconst_0
11: anewarray #61 // class java/lang/Object
14: putstatic #49 // Field CGLIB$emptyArgs:[Ljava/lang/Object;
17: ldc #77 // String package_name.impl.JobProcessingDaoImpl$$EnhancerByCGLIB$$f8ed98b3
19: invokestatic #83 // Method java/lang/Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
22: astore_0
23: iconst_2
24: anewarray #85 // class java/lang/String
27: dup
28: iconst_0
29: ldc #86 // String destroy
31: aastore
32: dup
33: iconst_1
34: ldc #87 // String ()V
36: aastore
37: ldc #89 // String org.springframework.beans.factory.DisposableBean
39: invokestatic #83 // Method java/lang/Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
42: dup
43: astore_1
44: invokevirtual #93 // Method java/lang/Class.getDeclaredMethods:()[Ljava/lang/reflect/Method;
47: invokestatic #99 // Method net/sf/cglib/core/ReflectUtils.findMethods:([Ljava/lang/String;[Ljava/lang/reflect/Method;)[Ljava/lang/reflect/Method;
50: dup
51: iconst_0
52: aaload
53: putstatic #47 // Field CGLIB$destroy$10$Method:Ljava/lang/reflect/Method;
56: aload_1
57: aload_0
58: ldc #87 // String ()V
60: ldc #86 // String destroy
62: ldc #100 // String CGLIB$destroy$10
64: invokestatic #106 // Method net/sf/cglib/proxy/MethodProxy.create:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Lnet/sf/cglib/proxy/MethodProxy;
67: putstatic #51 // Field CGLIB$destroy$10$Proxy:Lnet/sf/cglib/proxy/MethodProxy;
70: pop
71: return
72: return
final void CGLIB$destroy$10() throws java.lang.Exception;
Code:
0: aload_0
1: invokespecial #39 // Method package_name/dataaccesscomponent/impl/JobProcessingDaoImpl.destroy:()V
4: return
public final void destroy() throws java.lang.Exception;
Code:
0: aload_0
1: getfield #41 // Field CGLIB$CALLBACK_1:Lnet/sf/cglib/proxy/MethodInterceptor;
4: dup
5: ifnonnull 17
8: pop
9: aload_0
10: invokestatic #45 // Method CGLIB$BIND_CALLBACKS:(Ljava/lang/Object;)V
13: aload_0
14: getfield #41 // Field CGLIB$CALLBACK_1:Lnet/sf/cglib/proxy/MethodInterceptor;
17: dup
18: ifnull 37
21: aload_0
22: getstatic #47 // Field CGLIB$destroy$10$Method:Ljava/lang/reflect/Method;
25: getstatic #49 // Field CGLIB$emptyArgs:[Ljava/lang/Object;
28: getstatic #51 // Field CGLIB$destroy$10$Proxy:Lnet/sf/cglib/proxy/MethodProxy;
31: invokeinterface #57, 5 // InterfaceMethod net/sf/cglib/proxy/MethodInterceptor.intercept:(Ljava/lang/Object;Ljava/lang/reflect/Method;[Ljava/lang/Object;Lnet/sf/cglib/proxy/MethodProxy;)Ljava/lang/Object;
36: return
37: aload_0
38: invokespecial #39 // Method package_name/dataaccesscomponent/impl/JobProcessingDaoImpl.destroy:()V
41: return
public static net.sf.cglib.proxy.MethodProxy CGLIB$findMethodProxy(net.sf.cglib.core.Signature);
Code:
0: aload_0
1: invokevirtual #65 // Method java/lang/Object.toString:()Ljava/lang/String;
4: dup
5: invokevirtual #69 // Method java/lang/Object.hashCode:()I
8: tableswitch { // 1460027707 to 1460027707
1460027707: 28
default: 40
}
28: ldc #71 // String destroy()V
30: invokevirtual #75 // Method java/lang/Object.equals:(Ljava/lang/Object;)Z
33: ifeq 41
36: getstatic #51 // Field CGLIB$destroy$10$Proxy:Lnet/sf/cglib/proxy/MethodProxy;
39: areturn
40: pop
41: aconst_null
42: areturn
public package_name.dataaccesscomponent.impl.JobProcessingDaoImpl$$EnhancerByCGLIB$$f8ed98b3();
Code:
0: aload_0
1: dup
2: invokespecial #107 // Method package_name/dataaccesscomponent/impl/JobProcessingDaoImpl."<init>":()V
5: invokestatic #45 // Method CGLIB$BIND_CALLBACKS:(Ljava/lang/Object;)V
8: return
public static void CGLIB$SET_THREAD_CALLBACKS(net.sf.cglib.proxy.Callback[]);
Code:
0: getstatic #27 // Field CGLIB$THREAD_CALLBACKS:Ljava/lang/ThreadLocal;
3: aload_0
4: invokevirtual #112 // Method java/lang/ThreadLocal.set:(Ljava/lang/Object;)V
7: return
public static void CGLIB$SET_STATIC_CALLBACKS(net.sf.cglib.proxy.Callback[]);
Code:
0: aload_0
1: putstatic #115 // Field CGLIB$STATIC_CALLBACKS:[Lnet/sf/cglib/proxy/Callback;
4: return
static {};
Code:
0: invokestatic #131 // Method CGLIB$STATICHOOK2:()V
3: return
}
Caused by: java.lang.NoSuchMethodError: pakcage_name.dataaccesscomponent.JobProcessingDao.save(Lpakcage_name/businessentities/JobProcessing;)J
at package_name.synchandler.impl.SyncHandlerImpl.createCompositeJobProcessing(SyncHandlerImpl.java:1232)
附注。spring 3.1.0.版本
抛出异常的行为是否可能抛出不同的异常? 为了抛出异常,必须(可选地)分配新对象,并调用其构造函数(隐式调用fillinstacktrace)。在某些情况下,听起来像addSupressed也被称为。那么如果没有足够的内存会发生什么呢?JVM是否需要预分配内置异常?例如,(1/0)会抛出OutOfMemoryError而不是ArithmeticException吗? 此外,构造函数是一个方法调用,因
这是我的申请 数据源:类型:com.zaxxer.hikari.HikariDataSource主要: 这是我的入门: 这是我的例外: 2017-11-21 10:10:33.126线程“main”中的表现:java.lang.运行时异常: java.lang.ClassCastException: 无法将 com.mysql.cj.jdbc.Driver to javax.sql.DataSou
问题内容: 我有一个关于Eclipse,Wicket,Spring,Hibernate的项目。一切正常,除了:当我尝试 服务变量为空?在我使用此构造的任何其他地方,“ service”都不为null且运行良好。请帮我解决这个问题。 问题答案: @SpringBean仅在Component的任何子类中起作用。 您需要在构造函数中执行以下操作 小门1.4 小门1.5+ 参见“通用IDataProvid
我是jUnit和mockito的新手。对于虚空的嘲弄是如何发挥作用的,我完全感到困惑。在这里,如果名称是“hello”,则函数抛出一个异常。但当我测试它时,它并没有抛出异常... 测试 }
问题内容: 我试图在Netbeans中重构一个大型程序,但我有点迷茫。我从来没有非常模块化,但是现在通过实际学习如何做到这一点来尝试纠正这种情况,并在将来纠正这种情况。不幸的是,我在将某些教程翻译成我的程序时遇到了麻烦。所以我希望这里有人可以帮忙。目前,我正在尝试分解一部分采用特定格式的文件并制成表格的代码。我知道我需要创建一个类并使用它来创建表对象,但是我不确定如何做。我有一个主文件,用于获取文
问题内容: 我有这样的方法: 我想抛出一个内。编译器不允许我这样做,因为不允许将我的方法扔在那里。但是我需要抛出一个的子类来进行测试 (我不能抛出Unchecked)。显然这是一个hack,但我需要进行测试。我尝试过EasyMock,但它也不允许我这样做。任何想法如何做到这一点? 谢谢,肖恩·阮 问题答案: 方法1: Alexey Ragozin的这篇文章介绍了如何使用泛型技巧引发未声明的检查异常