java8中的Optional容器类,避免空指针异常

简介: java8中使用Optional容器类来尽可能的避免或快速定位空指针异常

java8中使用Optional容器类来尽可能的避免或快速定位空指针异常


Optional类的基本使用

public class Person {
    private Integer age;
    private Double salary;
    public Person() {
    }
    public Person(Integer age, double salary) {
        this.age = age;
        this.salary = salary;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public double getSalary() {
        return salary;
    }
    public void setSalary(double salary) {
        this.salary = salary;
    }
    @Override
    public String toString() {
        return "Person{" +
                "age=" + age +
                ", salary=" + salary +
                '}';
    }
}
//of方法 创建一个Optional对象
        Optional<Person> of = Optional.of(new Person());
        Optional<Person> of1 = Optional.of(null);
        System.out.println(of.get());
        System.out.println(of1.get());//java.lang.NullPointerException
        //empty方法 创建一个空的Optional实例
        Optional<Person> empty = Optional.empty();
        System.out.println(empty.get());  //java.util.NoSuchElementException: No value present
        //ofNullable(T t) 如果T不为空,创建Optional实例,如果为空,创建空实例,下面就是这个方法的实现,综合了上面两个方法
//        public static <T> Optional<T> ofNullable(T value) {
//            return value == null ? empty() : of(value);
//        }
        Optional<Person> ofNullable = Optional.ofNullable(new Person());
        //isPersent方法 判断是否包含空值
        Optional<Person> isPer= Optional.ofNullable(new Person());
            //如果不为空 输出
        if(isPer.isPresent()){
            System.out.println(isPer.get());
        }
        //orElse(T t) 如果调用对象包含值 返回该值,否则返回t
        Optional<Person> orEl = Optional.ofNullable(null);
        System.out.println(orEl.orElse(new Person(12, 222))); //输出 Person{age=12, salary=222.0}
        //orElseGet(Supplier s) 如果调用对象包含值 返回该值,否则返回s获取的值
        Optional<Object> orEG = Optional.ofNullable(null);
        System.out.println(orEG.orElseGet(() -> new Integer(33))); //输出33
        //map(Function f) 如果有值 对其处理,并返回处理后的Optional,否则返回Optional.empty()
        Optional<Person> oMap = Optional.ofNullable(new Person(12, 2222));
        Optional<Integer> oAge = oMap.map(e -> e.getAge());
        System.out.println(oAge.get()); //输出12
        //flatMap(Function mapper) 与map类似,就是返回值必须是Optional   进一步避免空指针异常
        Optional<Person> oFlatMap = Optional.ofNullable(new Person(12, 2222));
        Optional<Integer> oFlatAge = oMap.flatMap(e -> Optional.of(e.getAge()));
        System.out.println(oAge.get());  //输出12



这里放一个例子


有一个Teacher类,Teacher中有一个Student属性,

public class Teacher {
    private Optional<Student> student = Optional.empty();
    public void setStudent(Optional<Student> student) {
        this.student = student;
    }
    public Optional<Student> getStudent() {
        return student;
    }
}

Student类有一个name属性


public class Student {
    private String name;
    public Student(String name) {
        this.name = name;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}


使用Optional容器来避免空指针异常


public static void main(String[] args) {
        Optional<Teacher> op = Optional.ofNullable(null);
        String studentName = getStudentName(op);
        System.out.println(studentName);
    }
    public static String getStudentName(Optional<Teacher> teacher){
        return teacher.orElse(new Teacher())
                .getStudent()
                .orElse(new Student("小明"))
                .getName();
    }


相关文章
|
24天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
48 1
|
24天前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
30 1
|
17天前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
39 8
|
25天前
|
IDE 前端开发 Java
怎样避免 Java 中的 NoSuchFieldError 异常
在Java中避免NoSuchFieldError异常的关键在于确保类路径下没有不同版本的类文件冲突,避免反射时使用不存在的字段,以及确保所有依赖库版本兼容。编译和运行时使用的类版本应保持一致。
60 7
|
26天前
|
Java 编译器
如何避免在 Java 中出现 NoSuchElementException 异常
在Java中,`NoSuchElementException`通常发生在使用迭代器、枚举或流等遍历集合时,尝试访问不存在的元素。为了避免该异常,可以在访问前检查是否有下一个元素(如使用`hasNext()`方法),或者使用`Optional`类处理可能为空的情况。正确管理集合边界和条件判断是关键。
52 6
|
26天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
1月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
86 4
|
29天前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
19 1
|
1月前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
49 2
|
2天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
116 77