Jar文件中的Guice和思考

时间:2012-01-08 18:50:18

标签: java reflection guice google-reflections

我正在尝试使用Google Guice(3.0)和Google Reflections(0.9.6)。

我有以下文件:

Operation.java:

package com.company1.calculator;

public interface Operation {
    public int apply(int a, int b);
}

Addition.java:

package com.company1.calculator;

public class Addition implements Operation {
    @Override
    public int apply(int a, int b) {
        return a + b;
    }
}

其他各种"操作"课程分布在多个包中。

CalculatorModule.java:

package com.company1.calculator;

import com.google.inject.AbstractModule;
import com.google.inject.multibindings.MapBinder;
import org.reflections.Reflections;

public class CalculatorModule extends AbstractModule {
    @Override
    protected void configure() {
        Reflections reflections = new Reflections("");
        MapBinder<String, Operation> map = MapBinder.newMapBinder(binder(), String.class, Operation.class);
        for (Class<? extends Operation> o : reflections.getSubTypesOf(Operation.class)) {
            map.addBinding(o.getSimpleName()).to(o);
        }
    }
}

Calculator.java:

package com.company1.calculator;

import com.google.inject.Inject;

import java.util.Map;

public class Calculator {
    private Map<String, Operation> operations;

    @Inject
    public Calculator(Map<String, Operation> operations) {
        this.operations = operations;
    }

    public void printCalculations(int a, int b) {
        System.out.println("Calculator: " + a + " " + b);

        for (String s : operations.keySet()) {
            System.out.print(s + ": ");
            System.out.println(operations.get(s).apply(a, b));
        }
    }
}

最后, App.java:

package com.company1.calculator;

import com.google.inject.Guice;
import com.google.inject.Injector;

public class App {
    public static void main(String[] args) {
        Injector injector = Guice.createInjector(new CalculatorModule());
        Calculator c = injector.getInstance(Calculator.class);
        c.printCalculations(3, 3);
    }
}

在IntelliJ中执行 App.java 后,我得到以下输出,如预期的那样:

  

计算器:3 3
  模数:0
  分部:1   乘法:9
  增加:6

但是,当我将此应用程序打包为jar时,我只得到以下输出:

  

计算器:3 3

为什么会这样,我该如何解决?我发现的最接近的事情是Issue 48,但是这个问题在2011年5月就已经确定了。肯定会在现在进入Maven ......

1 个答案:

答案 0 :(得分:2)

我能够完全按照描述重现这一点。问题似乎是默认的Reflections构造函数尝试在磁盘上找到可以找到每个给定参数的位置。当在IDE中传递“”时,它会找到/ bin目录,当从/tmp/so8780228.jar运行时,它会找到/ tmp /(ConfigurationBuilder.java:87处的断点)

简单的解决方法是提供除“”之外的其他内容,这使得配置构建没有有用的信息,而是提供类似“com.company1”的内容,可以在一个位置找到。

Reflections reflections = new Reflections("com.company1");

在这种情况下,ConfigurationBuilder正确地找到要扫描的路径/tmp/so8780228.jar,一切都按预期工作。

或者,您可以与ConfigurationBuilder进行更多交互,并告诉它搜索类路径上的每个jar(例如迭代System.getProperty(java.class.path)并添加每个jar),但性能会受到影响。