34

メソッド内のフィールドのクラスを渡す必要があるコードがあります。私のコードの仕組みのために、私は参照オブジェクトのみを処理でき、プリミティブは処理できません。の型がプリミティブであるかどうかを簡単に判断Fieldし、適切なラッパークラスと交換する方法が必要です。したがって、コードでは、これまでに行ったことは次のようなものです。

Field f = getTheField(); // Dummy method that returns my Field
Class<?> c = f.getType();
if (c == int.class) {
    c = Integer.class;
}
else if (c == float.class) {
    c = Float.class;
}
// etc
myMethod(c);

これは、すべてのプリミティブ型を明示的にチェックし、それらを適切なラッパークラスと交換する必要があるという事実を除いて、正常に機能します。プリミティブ型はそれほど多くないので、すべてをリストするだけでも問題はないことがわかりましたが、もっと簡単でエレガントな方法があるのではないかと思いました。

4

8 に答える 8

45

Apache Commons Langには、これを行うためのユーティリティメソッド(ClassUtils.primitiveToWrapper())があります。これは、裏で同じように醜いものになりますが、少なくとも、それがいいふりをすることができます。

于 2009-11-09T23:27:50.270 に答える
43

私はそのように甘やかされているので、回答では Google Collections Library を使用しますが、必要に応じて、プレーンな HashMaps でそれを行う方法をおそらく見ることができます。

  // safe because both Long.class and long.class are of type Class<Long>
  @SuppressWarnings("unchecked")
  private static <T> Class<T> wrap(Class<T> c) {
    return c.isPrimitive() ? (Class<T>) PRIMITIVES_TO_WRAPPERS.get(c) : c;
  }

  private static final Map<Class<?>, Class<?>> PRIMITIVES_TO_WRAPPERS
    = new ImmutableMap.Builder<Class<?>, Class<?>>()
      .put(boolean.class, Boolean.class)
      .put(byte.class, Byte.class)
      .put(char.class, Character.class)
      .put(double.class, Double.class)
      .put(float.class, Float.class)
      .put(int.class, Integer.class)
      .put(long.class, Long.class)
      .put(short.class, Short.class)
      .put(void.class, Void.class)
      .build();

これについて JDK に何も存在しないのは奇妙ですが、実際には何もありません。

編集:これをリリースしたことを完全に忘れていました:

http://google.github.io/guava/releases/21.0/api/docs/com/google/common/primitives/Primitives.html

これには、wrap() メソッドに加えて、unwrap() およびその他のいくつかの付随的なものがあります。

于 2009-11-09T23:24:31.520 に答える
8

class.isPrimitive() を呼び出してプリミティブかどうかを知ることができますが、JDK 内でクラスを変換するためのボクシング メソッドはありません。これに関連する未解決のバグが少なくとも 1 つあります。

于 2009-11-09T23:21:51.600 に答える