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 {}