Guice - 如何使用绑定注释来构建对象列表

时间:2012-11-01 10:44:38

标签: dependency-injection guice

我创建了Guice绑定注释,允许我根据注释绑定类的两个不同实例,例如:

bind(Animal.class).withAnnotation(Cat.class).toInstance(new Animal("Meow"));
bind(Animal.class).withAnnotation(Dog.class).toInstance(new Animal("Woof"));

我希望能够创建一个提供List方法的提供者方法,该方法是我的一个类的依赖项,但是无法弄清楚如何使用这个注释:

@Provider
List<Animal> provideAnimalList() {
    List<Animal> animals = new ArrayList<Animal>();
    animals.add(@Cat Animal.class); // No, but this is what I want
    animals.add(@Dog Animal.class); // No, but this is what I want
    return animals;
}

所以我假设我只能在List的add()方法的参数中使用注释...但是没有。

我该如何接近这个?在我看来,仅仅new动物类的两个实例会更简单,也许这不是如何使用绑定注释。

我很欣赏有关在这种情况下最佳使用绑定注释的评论。

由于

1 个答案:

答案 0 :(得分:6)

如果它真的是你想要的,这里有一个可行的解决方案:

public class AnimalModule extends AbstractModule {
    @Override
    protected void configure() {
        bind(Animal.class).annotatedWith(Cat.class).toInstance(new Animal("Meow"));
        bind(Animal.class).annotatedWith(Dog.class).toInstance(new Animal("Woof"));
    }

    @Provides
    List<Animal> provideAnimalList(@Cat Animal cat, @Dog Animal dog) {
        List<Animal> animals = new ArrayList<Animal>();
        animals.add(cat);
        animals.add(dog);
        return animals;
    }

    public static void main(String[] args) {
        List<Animal> animals = Guice.createInjector(new AnimalModule()).getInstance(Key.get(new TypeLiteral<List<Animal>>() {
        }));
        for (Animal animal : animals) {
            System.out.println(animal);
        }
    }
}

注释:

@Retention(value = RetentionPolicy.RUNTIME)
@BindingAnnotation
public @interface Cat {
}

输出:

Animal{sound='Meow'}
Animal{sound='Woof'}

然而

  • 不要创建特定的注释,在这种情况下似乎没有必要。请改用@Named
  • 您可以考虑Multibindings来解决该问题。