在我之前的文章“在自定义注解中使用哈希映射”中,我解释了如何使用枚举常量在注解中使用HashMap。
嵌套注解也可以用于映射键值对。
注解中支持的类型列表
需要两个自定义注解。第一个注解(例如MapItem)包含一个键值对,第二个注解(例如MapItems)包含一个MapItem注解列表。
注解@MapItem表示单个键值对。
<code class="language-java">@Target(ElementType.FIELD) public @interface MapItem { String key(); String value(); }</code>
注解@MapItems定义了一个MapItem列表。
<code class="language-java">@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.FIELD) public @interface MapItems { MapItem[] items(); }</code>
@MapItem注解列表设置在@MapItems注解中。
<code class="language-java">class ExampleDto { @MapItems(items = { @MapItem(key = "1", value = "MALE"), @MapItem(key = "2", value = "FEMALE"), @MapItem(key = "6", value = "DIVERS") }) public String salutation; }</code>
MapItemsTest测试MapItems注解。测试在salutation字段上进行。
为了演示如何使用@MapItem列表,我从@MapItem创建一个HashMap,并将其与预期的HashMap进行比较。
<code class="language-java">class MapItemsTest { @Test void testMapItems() throws NoSuchFieldException { Field field = ExampleDto.class.getDeclaredField("salutation"); field.setAccessible(true); MapItems annotation = field.getAnnotation(MapItems.class); Map<String, String> mappingItems = Arrays .stream(annotation.items()) .collect( Collectors.toMap( MapItem::key, MapItem::value ) ); assertEquals( new HashMap<>() {{ put("1", "MALE"); put("2", "FEMALE"); put("6", "DIVERS"); }}, mappingItems ); } }</code>
这是一个巧妙的解决方案,易于实现。
例如,如果键值对要在验证器中使用,则必须间接获取它们。
https://www.php.cn/link/164710e8521a5b39302f816392f05bc2
以上是在自定义注释中对键值对使用嵌套注释的详细内容。更多信息请关注PHP中文网其他相关文章!