NullPointerException은 Java 코드에서 가장 일반적인 예외입니다. 가장 가능성이 높은 시나리오를 다음 5가지 유형으로 분류합니다.
매개변수 값은 Integer와 같은 패키징 유형으로 사용될 경우 자동 unboxing으로 인해 null 포인터 예외가 발생합니다.
문자열을 비교할 때 널 포인터 예외가 발생합니다.
ConcurrentHashMap과 같은 컨테이너는 키 및 값이 널인 것을 지원하지 않으며, 널 키 또는 값을 강제로 적용하면 널 포인터 예외가 발생합니다. 개체에 B가 포함되어 있는 경우 개체 A의 필드를 통해 B를 얻은 후 필드에서 null인지 확인하지 않고 B의 메서드를 계단식으로 배열하면 메서드나 원격 서비스에서 반환된 목록이 비어 있지 않고 null이고 목록이 null인 경우 null 포인터 예외가 발생합니다. null을 확인하지 않고 직접 호출됩니다. 메서드에서 null 포인터 예외가 발생했습니다.
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"; } }
수정 아이디어는 다음과 같습니다.
ConcurrentHashMap의 경우 Key와 Value 모두 null을 지원하지 않으므로 null을 저장하지 않도록 수정되었습니다. HashMap의 Key와 Value는 null을 저장할 수 있는 반면 ConcurrentHashMap은 HashMap의 스레드 안전 버전인 것처럼 보이지만 null 값의 Key와 Value를 지원하지 않습니다. 이는 오해가 쉽게 발생할 수 있는 부분입니다.
fooService.getBarService().bar().equals("OK")와 같은 계단식 호출의 경우 fooService 및 getBarService() 메서드의 반환 값을 포함하여 null을 확인해야 하는 곳이 많습니다. , bar 메소드의 반환 값입니다. if-else를 사용하여 null을 확인하는 경우 여러 줄의 코드가 필요할 수 있지만 Optional을 사용하면 한 줄의 코드로 충분합니다.
rightMethod에서 반환된 List의 경우 null인지 확인할 수 없으므로 size 메서드를 호출하여 목록 크기를 얻기 전에 Optional.ofNullable을 사용하여 반환 값을 래핑한 다음 .orElse를 전달할 수도 있습니다. (Collections.emptyList()) 구현에서는 List가 null인 경우 빈 List를 얻고 마지막으로 size 메서드를 호출합니다.
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(); }
age의 경우 클라이언트가 age를 업데이트하려면 유효한 age를 전달해야 한다고 생각합니다. 값이 비어 있는 경우 Optional orElseThrow 메서드를 사용하여 IllegalArgumentException을 발생시킬 수 있습니다. .
닉네임은 데이터베이스에 있는 이름이 null일 수 없기 때문에 닉네임과 데이터베이스에서 가져온 이름을 게스트로 안전하게 설정할 수 있습니다.
위 내용은 Java에서 널 포인터 예외를 처리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!