多线程时Autowired自动注入问题

在多线程时使用@Autowired总是获取不到bean,原因是:new thread不在spring容器中,也就无法获得spring中的bean对象。

解决方法:手动获取

package com.test.configs;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class BeanContext implements ApplicationContextAware {

	private static ApplicationContext applicationContext;
	
	public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
		BeanContext.applicationContext = applicationContext;
	}
	
	public static ApplicationContext getApplicationContext(){
		return applicationContext;
	}
	
	@SuppressWarnings("unchecked")
	public static <T> T getBean(String name) throws BeansException {
		return (T)applicationContext.getBean(name);
	}
	
	public static <T> T getBean(Class<T> clz) throws BeansException {
	    return (T)applicationContext.getBean(clz);
	}
}

创建thread


package com.test.handler;

import com.test.configs.BeanContext;
import com.test.service.TestService;
import com.test.model.User;

/**
 * created by huguoju on 2017/11/13.
 */
public class TestHandler implements Runnable {

    private User user;
    private TestService testService;
    @Override
    public void run() {
        this.testService= BeanContext.getApplicationContext().getBean(TestService.class);
        User user=testService.queryUserById(11);
    }

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }
}




在其他service里调用

ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("upFinancial-pool-%d").build();
            ExecutorService pool = new ThreadPoolExecutor(corePoolSize, maxPoolSize,
                    6000L, TimeUnit.MILLISECONDS,
                    new LinkedBlockingDeque<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
            UpFinancialContractHandler handler=new UpFinancialContractHandler();
            handler.setUser(user);
            pool.execute(handler);





  • 7
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
多线程环境下,使用@Autowired注解可能会出现失效的情况。原因是多线程环境下,多个线程同访问同一个对象的实例,可能出现竞争条件,导致注入失败。 自动注入(@Autowired)是Spring框架提供的依赖注入的方式,用于自动装配Bean对象。当多个线程同使用@Autowired注解来注入同一个对象,可能会出现以下情况之一: 1. 线程之间存在竞争条件:如果多个线程同对同一个对象进行注入,可能会导致其中一个线程的注入被后来的线程覆盖,最终只有最后一个线程成功注入。 2. Bean对象的状态改变:在多线程环境下,如果多个线程同对Bean对象进行修改,可能会导致Bean对象的状态发生变化。而@Autowired注解是在Bean对象创建完成后进行注入的,如果Bean对象的状态改变了,可能会导致注入失败。 为了解决多线程环境下@Autowired失效的问题,可以考虑以下方案: 1. 使用局部变量:在多线程环境下,将需要注入的对象作为局部变量使用,而不是直接注入到类成员变量中。每个线程都使用独立的局部变量,可以避免线程之间的竞争条件。 2. 使用线程安全的依赖注入方式:可以使用线程安全的依赖注入方式,如构造函数注入或Setter方法注入。这些方式可以保证在多线程环境下对象的正确注入。 3. 使用ThreadLocal:可以使用ThreadLocal来保证每个线程都有独立的对象实例。在需要使用Autowired注入的地方,通过ThreadLocal获取对象实例,确保每个线程使用的是独立的实例。 总之,多线程环境下使用@Autowired注解可能会出现失效的情况,需要针对具体的情况选择合适的解决方案来避免注入失效问题
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值