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();
    }


相关文章
|
3天前
|
自然语言处理 Java API
Java 8的Stream API和Optional类:概念与实战应用
【5月更文挑战第17天】Java 8引入了许多重要的新特性,其中Stream API和Optional类是最引人注目的两个。这些特性不仅简化了集合操作,还提供了更好的方式来处理可能为空的情况,从而提高了代码的健壮性和可读性。
26 7
|
1天前
|
安全 Java 容器
Java一分钟之-并发编程:线程安全的集合类
【5月更文挑战第19天】Java提供线程安全集合类以解决并发环境中的数据一致性问题。例如,Vector是线程安全但效率低;可以使用Collections.synchronizedXxx将ArrayList或HashMap同步;ConcurrentHashMap是高效线程安全的映射;CopyOnWriteArrayList和CopyOnWriteArraySet适合读多写少场景;LinkedBlockingQueue是生产者-消费者模型中的线程安全队列。注意,过度同步可能影响性能,应尽量减少共享状态并利用并发工具类。
16 2
|
2天前
|
安全 Java 容器
Java一分钟之-并发编程:并发容器(ConcurrentHashMap, CopyOnWriteArrayList)
【5月更文挑战第18天】本文探讨了Java并发编程中的`ConcurrentHashMap`和`CopyOnWriteArrayList`,两者为多线程数据共享提供高效、线程安全的解决方案。`ConcurrentHashMap`采用分段锁策略,而`CopyOnWriteArrayList`适合读多写少的场景。注意,`ConcurrentHashMap`的`forEach`需避免手动同步,且并发修改时可能导致`ConcurrentModificationException`。`CopyOnWriteArrayList`在写操作时会复制数组。理解和正确使用这些特性是优化并发性能的关键。
9 1
|
4天前
|
设计模式 算法 Java
Java的前景如何,好不好自学?,万字Java技术类校招面试题汇总
Java的前景如何,好不好自学?,万字Java技术类校招面试题汇总
|
5天前
|
安全 Java 开发者
Java一分钟之-文件与目录操作:Path与Files类
【5月更文挑战第13天】Java 7 引入`java.nio.file`包,`Path`和`Files`类提供文件和目录操作。`Path`表示路径,不可变。`Files`包含静态方法,支持创建、删除、读写文件和目录。常见问题包括:忽略异常处理、路径解析错误和权限问题。在使用时,注意异常处理、正确格式化路径和考虑权限,以保证代码稳定和安全。结合具体需求,这些方法将使文件操作更高效。
11 2
|
5天前
|
安全 Java 开发者
Java一分钟之-Optional类:优雅处理null值
【5月更文挑战第13天】Java 8的`Optional`类旨在减少`NullPointerException`,提供优雅的空值处理。本文介绍`Optional`的基本用法、创建、常见操作,以及如何避免错误,如直接调用`get()`、误用`if (optional != null)`检查和过度使用`Optional`。正确使用`Optional`能提高代码可读性和健壮性,建议结合实际场景灵活应用。
22 3
|
Java API 容器
Java8新特性之空指针异常的克星Optional类
Java8新特性之空指针异常的克星Optional类
107 0
|
3天前
|
Java 测试技术
Java多线程的一些基本例子
【5月更文挑战第17天】Java多线程允许并发执行任务。示例1展示创建并启动两个`MyThread`对象,各自独立打印&quot;Hello World&quot;。示例2的`CounterExample`中,两个线程(IncrementThread和DecrementThread)同步地增加和减少共享计数器,确保最终计数为零。这些例子展示了Java线程的基本用法,包括线程同步,还有如Executor框架和线程池等更复杂的用例。
10 0
|
4天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
1天前
|
Java
Java一分钟之-并发编程:线程间通信(Phaser, CyclicBarrier, Semaphore)
【5月更文挑战第19天】Java并发编程中,Phaser、CyclicBarrier和Semaphore是三种强大的同步工具。Phaser用于阶段性任务协调,支持动态注册;CyclicBarrier允许线程同步执行,适合循环任务;Semaphore控制资源访问线程数,常用于限流和资源池管理。了解其使用场景、常见问题及避免策略,结合代码示例,能有效提升并发程序效率。注意异常处理和资源管理,以防止并发问题。
23 2
http://www.vxiaotou.com