关于程序员:Optional-类和重复注解与类型注解

5次阅读

共计 1454 个字符,预计需要花费 4 分钟才能阅读完成。

optional 类

Optional<T> 类 (java.util.Optional) 是一个容器类,代表一个值存在或不存在,
原来用 null 示意一个值不存在,当初 Optional 能够更好的表白这个概念。并且
能够防止空指针异样。

罕用办法

  • Optional.of(T t) : 创立一个 Optional 实例
  • Optional.empty() : 创立一个空的 Optional 实例
  • Optional.ofNullable(T t): 若 t 不为 null, 创立 Optional 实例, 否则创立空实例
  • isPresent() : 判断是否蕴含值
  • orElse(T t) : 如果调用对象蕴含值,返回该值,否则返回 t
  • orElseGet(Supplier s) : 如果调用对象蕴含值,返回该值,否则返回 s 获取的值
  • map(Function f): 如果有值对其解决,并返回解决后的 Optional,否则返回 Optional.empty()
  • flatMap(Function mapper): 与 map 相似,要求返回值必须是 Optional

反复注解

# 申明一个注解,而后 `@Repeatable`,能够对用户暗藏掉注解容器,我只须要在 @MyAnnotation 注解的定义上加上这个注解,
@Repeatable(MyAnnotations.class) // 反复注解,须要指定注解容器
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE,TYPE_PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotation {String value() default "默认值";
}
#注解容器
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotations {MyAnnotation[] value();}

# 应用,取得注解上的参数
// 反复注解和类型注解   理解就行
public class TestAnnotation {

    @Test
    public void test1() throws Exception{
        Class<TestAnnotation> clazz = TestAnnotation.class;
        Method method = clazz.getMethod("show");
        MyAnnotation[] type = method.getAnnotationsByType(MyAnnotation.class);
        for (MyAnnotation t:type){System.out.println(t.value());
        }
    }

    @MyAnnotation("hello")
    @MyAnnotation("world")
    public void show(/*@MyAnnotation("aaa") String str*/){}}

类型注解 Type Annotations

类型注解是一种能够放在任何应用类型的地位上的正文(注:在 Java 8 之前的版本中,只能在申明式前应用注解)。在代码实现上,Java 8 为注解减少了两个新的注解类型:

@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
public @interface Test {}
正文完
 0