这个SwingWorker是不是在ThreadPoolExecutor中重用Threads?

时间:2010-06-23 14:29:38

标签: java multithreading swingworker

作为我的最后一年项目的一部分,我开发了一个桌面应用程序,如果存在这样的东西,它就属于“图形IDE”的类别。我已经实现了Jessy James Garrett Visual Vocabulary for Information Architecture and Interaction Design的一个小子集,因此用户可以绘制一个图表(换句话说是有向图),表示用户在webapp中的体验,为页面分配HTML模板并将一些代码写入连接器/一旦编译应用程序并且用户单击相应的超链接,将执行的转换。

(我不能发布多个超链接,但我指的是JJG视觉词汇中描述的用户体验元素之类的页面和连接器)

所以我正在使用不同的SwingWorkers生成一组C ++源文件,其中图表被翻译成。查看日志,我发现我的应用程序总是创建新线程,而不是重用它们。

15:29:55.750 [SwingWorker-pool-2-thread-26] DEBUG i.v.a.ui.worker.ConnectorGenerator - Building source code for transition: connector_29
15:29:55.750 [SwingWorker-pool-2-thread-26] DEBUG i.v.a.ui.worker.ConnectorGenerator - Project retrieved: sasdasdasd
15:29:55.750 [SwingWorker-pool-2-thread-26] INFO  i.v.a.webapp.htcpp.CTransition - Generated C:\Workspaces\PFC\aedifico-ui\sasdasdasd\connector_29_action.h...
15:29:55.750 [SwingWorker-pool-2-thread-26] INFO  i.v.a.webapp.htcpp.CTransition - Generated C:\Workspaces\PFC\aedifico-ui\sasdasdasd\connector_29_action.cpp...
15:29:55.750 [SwingWorker-pool-2-thread-26] DEBUG i.v.a.ui.worker.ConnectorGenerator - Transition generated at: C:\Workspaces\PFC\aedifico-ui\sasdasdasd/connector_29_action.cpp

我所有的工人都做同样的事情:

  1. 使用生成一对C ++源文件和头文件 Freemarker模板引擎。

  2. 通过EDT发送消息 发布过程机制 告知用户事情是怎样的 去。

  3. 我相信我已经仔细编码了SwingWorker。我特别担心FileWriter实例未按预期关闭,但我看不出ThreadPoolExecutor没有重用之前创建的线程的原因。

    神奇发生在ConnectorGeneratorBaseWorker扩展SwingWorker<V,T>,只保留与组件通信的行为,以向用户显示消息。

    public class ConnectorGenerator<Void> extends BaseWorker<Void> {
        @Override
        public Void doInBackground() {
            Transition transition = connector.getModel().getTransition();
            logger.debug("Building source code for transition: {}", transition.getName());    
            logger.debug("Project retrieved: {}", project.getName());
            try {
                publish("Generating transition (%s) source code at %s", transition.getName(), project.getBaseDir());
                /**
                 * Transition.build(String), attached below, is responsible of generating and writing the files
                 */
                transition.build(project.getBaseDir().getPath());
                publish("Transition generated.");
            } catch (BuilderException e) {
                logger.error("Error: {}", e);
                publish("There was an error that prevented generating %s's source code", transition.getName());
            }
            logger.debug("Transition generated at: {}/{}", project.getBaseDir(), transition.getSource());
    
            return null;
        }
    }
    

    Transition.build(String)方法,包括一个丑陋的地狱try-catch-finally块:

    @Override
    public void build(String path) throws BuilderException {            
        generateFile(String.format("%s%s%s", path, File.separator, getHeader()), "action.h.ftl");
        generateFile(String.format("%s%s%s", path, File.separator, getSource()), "action.cpp.ftl");     
    }
    
    private void generateFile(String path, String templateName) throws BuilderException {
        FileWriter out = null;
        try {
            Map<String, Object> model = new HashMap<String, Object>();
            model.put("transition", this);
            Configuration config = new Configuration();
            config.setClassForTemplateLoading(CTransition.class, "/");
            config.setObjectWrapper(ObjectWrapper.DEFAULT_WRAPPER);
    
            out = new FileWriter(path);
            freemarker.template.Template template = config.getTemplate(templateName);
            template.process(model, out, ObjectWrapper.BEANS_WRAPPER);
            stdout.info("Generated {}...", path);           
        } catch (IOException e) {
            throw new BuilderException(e);
        } catch (TemplateException e) {
            throw new BuilderException(e);
    } finally {
            if (out != null)
                try {
                    out.flush();
                    out.close();
                } catch (IOException e) {
                    throw new BuilderException(e);
                }
    }       
    }
    

    有没有人看到或知道我可能遗失的东西?

1 个答案:

答案 0 :(得分:1)