1

我需要将测试值放在一个类中,就像在这个简化的例子中一样:

import java.util.List;
import java.util.Map;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
public class TestVal {
  private static Map<Class<?>, Object> dummyValues = Maps.newHashMap();
  static {
    dummyValues.put(String.class, "Banana");
    dummyValues.put(Integer.class, 42);
  }
  @SuppressWarnings("unchecked")
  static final <T> T ofType(Class<T> type) {
    return (T) dummyValues.get(type);
  }
  public static void main(String[] args) {
    List<? extends Object> list =
        Lists.newArrayList(ofType(String.class), ofType(Integer.class));
    for (Object object : list) {
      System.out.printf("%s: %s%n", object, object.getClass().getName());
    }
  }
}

一旦运行,它会给我:

Banana: java.lang.String
42: java.lang.Integer

所以它作为一个“基本”系统很好。

不过,我想要更多的类型安全性。

我试图研究番石榴的ImmutableClassToInstanceMap但是......我觉得有点困难,看看这个方法签名:

public static
    <B, S extends B>
        ImmutableClassToInstanceMap<B>
            copyOf(
                Map<? extends Class<? extends S>,
                ? extends S> map
            )

残酷,不是吗?我如何将它用于“任何”类型?在 Google 的 Wiki 上没有看到示例。

我可以像上面那样“向上一步”而不是“一路走来”吗?我是否错过了另一种明显的方法来做同样的事情?

4

1 回答 1

8

诶?你需要做的ImmutableClassToInstanceMap就是像

ImmutableClassToInstanceMap<Object> map = ImmutableClassToInstanceMap
  .builder()
  .put(String.class, "foo")
  .put(Integer.class, 42)
  .build();

然后你只需打电话map.getInstance(String.class)出去String

上的泛型copyOf()很复杂但很有必要,但在这种情况下,您几乎肯定只想使用构建器。

于 2012-10-08T23:20:07.920 回答