NullPointerException ialah pengecualian yang paling biasa dalam kod Java Saya mengklasifikasikan senario yang paling mungkin ke dalam 5 jenis berikut:
Nilai parameter ialah jenis pembungkus seperti Integer , kerana Pengecualian penuding nol berlaku dalam penyahkotak automatik; sokongan Kekunci dan Nilai adalah batal, memaksa kekunci atau Nilai nol akan menghasilkan pengecualian penunjuk nol; medan tidak dibatalkan Pengecualian penunjuk nol berlaku apabila memanggil kaedah B dalam lata; semak.
private List<String> wrongMethod(FooService fooService, Integer i, String s, String t) { log.info("result {} {} {} {}", i + 1, s.equals("OK"), s.equals(t), new ConcurrentHashMap<String, String>().put(null, null)); if (fooService.getBarService().bar().equals("OK")) log.info("OK"); return null; } @GetMapping("wrong") public int wrong(@RequestParam(value = "test", defaultValue = "1111") String test) { return wrongMethod(test.charAt(0) == '1' ? null : new FooService(), test.charAt(1) == '1' ? null : 1, test.charAt(2) == '1' ? null : "OK", test.charAt(3) == '1' ? null : "OK").size(); } class FooService { @Getter private BarService barService; } class BarService { String bar() { return "OK"; } }
Idea pembaikan adalah seperti berikut:
Untuk penghakiman nol Integer, anda boleh menggunakan Optional.ofNullable untuk membina Pilihan, dan kemudian gunakan orElse(0 ) Gantikan null dengan nilai lalai dan kemudian lakukan operasi +1. Untuk perbandingan antara String dan literal, anda boleh meletakkan literal di hadapan, seperti "OK". sama dengan(s), supaya walaupun s adalah nol, pengecualian penunjuk nol tidak akan berlaku dan untuk dua pembolehubah rentetan yang mungkin null Untuk perbandingan sama, anda boleh menggunakan Objects.equals, yang akan melakukan pemprosesan null.
Untuk ConcurrentHashMap, memandangkan Kunci dan Nilainya tidak menyokong null, penyelesaiannya bukan untuk menyimpan null di dalamnya. Kunci dan Nilai HashMap boleh disimpan dalam null, manakala ConcurrentHashMap nampaknya merupakan versi HashMap yang selamat dari benang, tetapi ia tidak menyokong Kunci dan Nilai nilai nol Ini adalah tempat yang mudah berlaku salah faham.
Untuk Senarai yang dikembalikan oleh rightMethod, kerana ia tidak dapat disahkan sama ada ia adalah batal, sebelum memanggil kaedah saiz untuk mendapatkan saiz senarai, anda juga boleh menggunakan Optional.ofNullable untuk membalut mengembalikan nilai, dan kemudian lulus orElse(Collections.emptyList()) mencapai mendapatkan Senarai kosong apabila Senarai adalah batal, dan akhirnya memanggil kaedah saiz.
private List<String> rightMethod(FooService fooService, Integer i, String s, String t) { log.info("result {} {} {} {}", Optional.ofNullable(i).orElse(0) + 1, "OK".equals(s), Objects.equals(s, t), new HashMap<String, String>().put(null, null)); Optional.ofNullable(fooService) .map(FooService::getBarService) .filter(barService -> "OK".equals(barService.bar())) .ifPresent(result -> log.info("OK")); return new ArrayList<>(); } @GetMapping("right") public int right(@RequestParam(value = "test", defaultValue = "1111") String test) { return Optional.ofNullable(rightMethod(test.charAt(0) == '1' ? null : new FooService(), test.charAt(1) == '1' ? null : 1, test.charAt(2) == '1' ? null : "OK", test.charAt(3) == '1' ? null : "OK")) .orElse(Collections.emptyList()).size(); }
@PostMapping("right") public UserEntity right(@RequestBody UserDto user) { if (user == null || user.getId() == null) throw new IllegalArgumentException("用户Id不能为空"); UserEntity userEntity = userEntityRepository.findById(user.getId()) .orElseThrow(() -> new IllegalArgumentException("用户不存在")); if (user.getName() != null) { userEntity.setName(user.getName().orElse("")); } userEntity.setNickname("guest" + userEntity.getName()); if (user.getAge() != null) { userEntity.setAge(user.getAge().orElseThrow(() -> new IllegalArgumentException("年龄不能为空"))); } return userEntityRepository.save(userEntity); }
Atas ialah kandungan terperinci Bagaimana untuk mengendalikan pengecualian penunjuk nol di Jawa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!