このクラスを考えてみましょう:
public class MyClassOfMystery {
public static final int NO_FLAGS = ~0;
public static final int FIRST_FLAG = 1;
public static final int SECOND_FLAG = 1 << 1;
public static final int THIRD_FLAG = 1 << 2;
public static final int FOURTH_FLAG = 1 << 3;
@Retention(RetentionPolicy.SOURCE)
@IntDef(flag = true, value = {NO_FLAGS, FIRST_FLAG, SECOND_FLAG, THIRD_FLAG, FOURTH_FLAG})
public @interface MysteryFlags { }
... set flags, get flags, and use flags stuff.
}
私はよくこのようなものを作成してきましたMysteryFlags.
で設定した値を繰り返し処理できますMysteryFlagsか?
これは私が試したことです:
これは印刷されましたANNOTATION: @java.lang.annotation.Retention(value=SOURCE):
for (Annotation annotation : Flag.class.getAnnotations()) {
Log.d(TAG, String.format("ANNOTATION: %s", String.valueOf(annotation)));
}
これにより、null 配列アクセスで NPE がスローされました
for (ExtraAction enm : Flag.class.getEnumConstants()) {
Log.d(TAG, String.format("ENUM: %s", String.valueOf(enm)));
}
これらは何も出力しませんでした:
for (Field field : Flag.class.getFields()) {
Log.d(TAG, String.format("FIELD: %s", String.valueOf(field)));
}
と
for (Class<?> aClass : ExtraAction.class.getClasses()) {
Log.d(TAG, String.format("CLASS: %s", String.valueOf(aClass)));
}
値を配列に追加してそれを繰り返すだけでよいことはわかっていますが、それには別の配列を格納する必要があります。それは私がやったことですが、もっと良い方法があるかどうかはまだ疑問です。