java - @Autowired 不能在可运行的内部工作

标签 java multithreading spring-mvc autowired

我有一个可运行的任务,我正在尝试 Autowiring 字段,但是当我这样做时任务没有运行。 当我 Autowiring runnable 之外的字段时,它工作正常。为什么会这样?除了在内部 Autowiring 之外,还有其他更简洁的方法可以在 runnable 中获取 Autowiring 字段的新实例吗?

这是我的可运行方法`

Runnable task = new Runnable() {

                @Autowired
                ICruxPanelClientService CruxPanelClientService;

                public void run (){
            CruxPanelClientService.setCruxWebServiceBaseURL("http://10.41.181.23:8080");
            CronCruxModel m = new CronCruxModel();
            m = model1.get(model_var);
            System.out.println("EXECUTING");
            System.out.println(m.getService_status() + " ---------EXEexecution");
            System.out.println(m.getCat_name() + "Executing Name ");
        //  time = m.getService_time();
            UpdateCategoryRequest updateCategoryRequest = new UpdateCategoryRequest();
            CategoryModel categoryModel = new CategoryModel();
            categoryModel.setColor(m.getCat_color());
            categoryModel.setIcon(m.getCat_icon());
            categoryModel.setIconWhite(m.getCat_icon_white());
            categoryModel.setName(m.getCat_name());
            categoryModel.setId(m.getCat_id());
            categoryModel.setKey(m.getCat_catkey());
            categoryModel.setIndexOrder(m.getCat_indexOrder());
            updateCategoryRequest.setCategory(categoryModel);
            CruxPanelClientService.updateCategory(updateCategoryRequest);
            GetServiceDataIdByCategoryIdRequest request1 = new GetServiceDataIdByCategoryIdRequest();    
            request1.setId(m.getCat_id());
            GetServiceDataIdByCategoryIdResponse response1 = CruxPanelClientService.getServiceDataIdByCategoryId(request1);
            ArrayList<ServiceModel> service = new ArrayList<ServiceModel>();
            service = response1.getServiceModels();

            JSONArray json = new JSONArray();
            if(m.getService_order_succ_msg()==null)
            {
                json = new JSONArray();
            }
            else {

                 json = new JSONArray(m.getService_order_succ_msg());
            }
            String message = m.getService_order_succ_msg();

            for (int j=0;j<service.size();j++)
            {   
                UpdateServiceMasterRequest req = new UpdateServiceMasterRequest();
                ServiceModel s = new ServiceModel();
                s=service.get(j);
                ;
                JSONObject obj = new JSONObject();

                if(json.length()==0 ) 
                {
                    String ms = null;
                    s.setOrderSuccessMessage(ms);
                    req.setServiceModel(s);

                }

                else {

                    String message1 = json.get(j).toString();

                    if(message1.equals(null) || message1.equals("")) {
                        String ms = null;
                        s.setOrderSuccessMessage(ms);
                        req.setServiceModel(s);

                    }
                    else {
                        s.setOrderSuccessMessage(message1);

                        req.setServiceModel(s);

                    }
                }
                CruxPanelClientService.updateServiceMaster(req);

            }
            m.setService_status("executed");
            UpdateCronCruxRequest q = new UpdateCronCruxRequest();
            q.setCronCruxModel(m);
            CruxPanelClientService.updateCronCrux(q);

                }
            };`

最佳答案

问题是 spring 不控制 runnable 的创建。有几个可能的解决方案:

  1. 将可运行的创建放在某些服务、存储库、 Controller 、组件或任何由 spring 处理的内容中:

例子:

@Service
public class SomeService {

    @Autowired
    private ICruxPanelClientService cruxPanelClientService;

    public Runnable newRunnable() {

        return new Runnable() {

            public void run() {
                cruxPanelClientService <- will be visible here and injected
            }
        }
    }

}
  1. 将可运行对象创建为具有原型(prototype)作用域的 bean

例子:

@Configuration
public class Runnableconfiguration {

    @Bean
    @Scope("prototype")
    public Runnable newRunnbale(final ICruxPanelClientService cruxPanelClientService) {
        return new Runnable() {
            public void run() {
                cruxPanelClientService <- will be visible here
            }
        }
    }
}

关于java - @Autowired 不能在可运行的内部工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38026330/

相关文章:

linux - 无法使用 jre 1.7.0_05 在 scientific linux 上启动 MATLAB guis (GUIDE)

java - Jelly validateButton 无法访问 Java 方法

Java TreeSet 根据对象属性删除重复项

java - 如何在没有资源图像的情况下显示图像

ruby - ssl`sysread_nonblock' : end of file reached (EOFError)

c++ - G++ CAS 的奇怪行为

用于挂起线程的 C++ 线程池

java - Spring 中使用 Gson 的 Web 服务

spring - 使用 Spring 运行长流程的最佳方法是什么

java - 如何在java中使用spring解压上传的zip文件