인프런 커뮤니티 질문&답변
예외처리 관련 질문이 있습니다.
작성
·
162
0
안녕하세요 강의 잘 보고있습니다.
다름이 아니라 강의 중 시스템 예외상황이 아닌 비지니스 예외상황(ex. 중복멤버처리, 강의엔 없지만 만료쿠폰사용 등등)에서
exception을 던져 처리하시는 것으로 봤는데 제가 배우기로는 일반적으로 IO 등이 아닌 개발자가 예상가능한 상황에 대해서는
예외를 던지지 않고 null이나 값을 리턴함으로서 처리하는 것으로 알고 있습니다.
exception should be exceptional 이라는 구절처럼 말이죠.
혹시 해당 강의와 관련이 없는 부분이라 단순화 시켜 편의상 처리하신 것인지
아니면 실제로 실무에서는 exception을 던지는 것이 관행인지(외래키는 거는것이 정도이지만 그렇지않는 경우도 있는 것처럼)
궁금하여 글을 남깁니다. 감사합니다.
답변 1
1
안녕하세요. kd park님
강의에서는 편의상 예외를 반환한 것이 맞습니다. 안그러면 상태를 반환하는 리턴 값으로 처리하는 복잡한 로직이 들어갔겠지요?
이 부분은 상황이나 사람마다 생각이 조금씩 다르다고 생각됩니다.
그래서 제가 선호하는 방법을 말씀드릴께요. 이 부분은 정답이라기 보다는 개인적인 생각입니다.
저도 가급적 예외를 터트리지 않고, 앞에서 한번 체크하는 방식을 선호합니다. 다만 심각한 비즈니스 상황에서는 예외를 발생시키도록 클래스를 설계합니다. 예를 들어서 만료 쿠폰의 경우 앞에서 한번 만료인지 아닌지 체크하는 로직과, 그리고 실제 그 쿠폰을 사용하는 로직으로 분리되어 있으면, 체크하는 로직에서 대부분 걸려서 예외가 발생하지 않겠지요. 이렇게 예외가 발생하는 상황을 줄이고, 그래도 누군가 실수로 쿠폰을 체크하는 로직을 누락하고 쿠폰을 사용하는 로직을 호출한다면, 예외를 발생 시키는 것이 안전한 설계라 생각합니다.
감사합니다^^





