java.lang.ClassCastException解决方案(转)

碰到这样的错误提示信息一般是spring中AOP代理配置出现问题,在spring中代理的配置基本上有这么两种一种是基于JDK,而另外一种是CGLIB的代理。
碰到这样的错误提示信息一般是spring中AOP代理配置出现问题,在spring中代理的配置基本上有这么两种一种是基于JDK,而另外一种是CGLIB的代理。
基于JDK的代理是面向接口的,所有使用 Proxy 的对象都必须定义一个接口,而且用这些对象的代码也必须是对接口编程的,Proxy 生成的对象是接口一致的而不是对象一致的。Proxy 毕竟是通过反射实现的,必须在效率上付出代价:有实验数据表明,调用反射比一般的函数开销至少要大 10 倍。而且,从程序实现上可以看出,对 proxy class 的所有方法调用都要通过使用反射的 invoke 方法。因此,对于性能关键的应用,使用 proxy class 是需要精心考虑的,以避免反射成为整个应用的瓶颈。
CGLib代理同jdk代理采用不同的方式,它是采用修改java类文件而得到的。利用了CGLIB调用ASM库,ASM 能够通过改造既有类,直接生成需要的代码。增强的代码是硬编码在新生成的类文件内部的,没有反射带来性能上的付出。
新建一个公共类:
public class UserManager extends HibernateDaoSupport {
private Hashtable<NetUserinfo, Long> userDao = new Hashtable<NetUserinfo, Long>();
private Hashtable<NetRoleinfo, Long> roleDao = new Hashtable<NetRoleinfo, Long>();
public UserManager() {
}
public void saveUser() {
HibernateTemplate ht = this.getHibernateTemplate();
List<NetUserinfo> lst = this.getHibernateTemplate().find(
"from NetUserinfo");
for (NetUserinfo userinfo : lst) {
System.out.println(userinfo.getUserName());
}
}
}

第一种采用JDK代理:
applicationContext.xml
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
<bean id="userManager" class="sx.cj.security.service.UserManager"
scope="prototype">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
测试:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[] { "applicationContext-common.xml",
"applicationContext-beans.xml" });
IUserManager userManager = (IUserManager) appContext
.getBean("userManager");
userManager.saveUser();

在测试文件中必须采用接口的方式,才能获得BEAN对象。
第二种:采用CGLIB代理
applicationContext.xml
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
<bean id="userManager"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager">
<ref bean="transactionManager"></ref>
</property>
<property name="target">
<bean class="sx.cj.security.service.UserManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
</property>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
<property name="proxyTargetClass">
<value>true</value>
</property>
</bean>

测试文件
ApplicationContext appContext = new ClassPathXmlApplicationContext( 
new String[] { "applicationContext-common.xml",
"applicationContext-beans.xml" });
UserManager userManager = (UserManager) appContext
.getBean("userManager");
userManager.saveUser();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long 引用: 在执行时出现类型换错误:java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Long 引用: org.apache.ibatis.exceptions.PersistenceException: Error querying database. Cause: java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long 问题描述中提到的错误是java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.Integer,而不是java.lang.Long cannot be cast to java.lang.Integer。这个错误可能发生在数据库查询中,在执行查询时,将java.lang.Long类型错误地换为java.lang.Integer类型。 要解决这个问题,可以考虑以下几个步骤: 1. 检查数据库表中相应的列的数据类型是否为java.lang.Integer类型,而不是java.lang.Long类型。如果列的数据类型为java.lang.Long,请将其更改为java.lang.Integer。 2. 检查数据库连接是否正确,确保数据库连接的配置与实际情况相符。 3. 检查MyBatis的映射文件中的查询语句,确保查询结果被正确地映射为java.lang.Integer类型。 4. 如果以上步骤都没有解决问题,可以考虑重新编译和构建项目,以确保所有依赖项和配置文件都正确地加载和使用。 需要注意的是,这只是一种可能的解决方法,具体的解决方案可能根据实际情况而异。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long](https://blog.csdn.net/qq_36785719/article/details/90201942)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [关于hibernate执行select count( *) 出现java.lang.ClassCastException问题](https://blog.csdn.net/cekong0704/article/details/9944731)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值