Spring Mvc线程中对象的使用

开发中为了运行效率,我们会将一些非主流程游比较耗时间的操作剥离出主线程操作,另起一个线程处理,但在刚接触spring线程的时候,对对象的处理出现了问题,在使用的对象的时候依旧用了比较传统的@Resource注入,但运行之后却报空指针异常,请教别人之后才知道线程中无法使用注解注入对象,web容器启动之前是不会注入线程中的对象的,线程启动时web容器也无法感知。

那我们在线程中如何使用spring容器中的对象呢?我们可以使用spring上下文直接获取spring容器中的对象,将线程的分发与实现分离。

首先定义工具类:


记住该工具类也要被配置为spring的bean,否则无法实例化ApplicationContext导致空指针异常。在你的springbean配置文件加入如下配置:

<bean id="springBeanUtils" class="com.hujin.common.util.SpringBeanUtils"/>

此外。要实现ApplicationContext的自动装配,还需要在web.xml文件中加入如下配置:

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:spring/spring-*.xml</param-value>
</context-param>

<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
ContextLoaderListener的作用就是启动Web容器时,自动装配ApplicationContext的配置信息,context-param指定读取的spring配置,以上配置缺一不可,否则会导致空指针异常。

此外还有一个注意点,这是我犯得一个错误也在这儿说一下。我开始取bean的时候这样定义,发现报了NoBeanDefinition的错

private SupplyPoMapper supplyPoMapper = (SupplyPoMapper)SpringBeanUtils.getBean("SupplyPoMapper");
将getBean中的SupplyPoMapper改为小写supplyPoMapper解决了问题,spring注解扫描类到容器中时以小写字母开头命名。

 
 
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC 是一种基于Spring框架的Web开发框架,它是基于模型-视图-控制器(MVC)设计模式来组织和管理Web应用程序的开发的。数据库事务是保证数据操作的一致性和可靠性的重要机制。 在Spring MVC,数据库事务的实现主要依赖于Spring框架内置的事务管理器。Spring框架为我们提供了多种事务管理器的实现方式,例如基于JDBC的DataSourceTransactionManager和基于JPA的JpaTransactionManager等。这些事务管理器实现了Spring的PlatformTransactionManager接口,它负责管理和控制事务的生命周期。 Spring MVC使用注解@Transactional来标注需要参与事务管理的方法或类。被@Transactional标注的方法或类,会在运行时被Spring框架内置的AOP机制拦截,以实现事务的控制。当方法被调用时,Spring框架首先会检查当前线程是否已经有一个事务实例存在,如果不存在则创建一个新的事务,如果存在则加入已存在的事务。 一旦事务创建成功,Spring框架会开始执行方法体的业务逻辑操作。如果方法执行成功,事务将会继续提交,操作的结果将会永久保存到数据库。如果方法执行失败或发生异常,Spring框架会回滚事务,将操作的结果恢复到之前的状态。这样可以确保在出现异常情况时,数据库的数据不会被污染或损坏。 事务的提交和回滚是由Spring框架的事务管理器来完成的。事务管理器负责管理事务的开始、提交和回滚等操作,并与底层的数据库连接进行交互。Spring框架还提供了各种配置选项,可以通过配置文件或注解来灵活地控制事务的传播行为、隔离级别、超时设置等。这些配置选项可以根据实际业务需求进行调整,以提供更好的性能和可靠性。 总而言之,Spring MVC的数据库事务的实现原理是依赖于Spring框架提供的事务管理器和AOP机制。通过使用@Transactional注解,我们可以简单地将需要参与事务管理的方法或类进行标注,使其具备事务性的功能。这样可以实现对数据库操作的一致性和可靠性保证。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值