[JavaScript] try/catch/finally + throw (에러 핸들링)

일반적으로 에러가 발생하면 스크립트가 제대로 동작하지 못하게 된다.

이러한 에러를 사람이 완벽하게 예측하여 처리할 수 없기 때문에 try ~ catch 문법을 사용하면 예상치 못한 에러에대하여 대응을 할 수 있다.


try ~ catch 문법은 try 와 catch 라는 필수적인 두개의 블록이 존재하며 

상황에따라 추가하여 사용할 수 있는 finally 도 존재한다.


try {

// 수행할 코드

} catch (error) {

// 에러 핸들링

}

try 블럭 내부에 수행할 코드를 작성하고 해당코드가 정상적으로 실행되면 catch 블럭을 건너뛰고 다음 코드를 이어 실행한다.

반면에 try 블럭 내부에 수행할 코드에 에러가 발생하면 try 블럭 내부의 코드 실행이 중단되고 catch 블럭으로 에러에 대한 객체가 인자로 넘어가면서 catch 블럭안에서 에러를 처리할 수 있다.


매개변수 error로 전달되는 에러 객체에는 무슨 문제가 발생했는지에 대한 설명이 담겨있다.

인자로 전달된 error 객체에는 name, message, stack 프로퍼티가 존재한다.

각각의 프로퍼티를 알아보면

error.name : 에러 명칭

error.message : 에러에대한 상세 내용을 담고있는 메세지이다.

error.stack : 에러가 발생한 순간의 스택 (디버깅시 사용)


try ~ catch 문법은 런타임 환경에서 실행되며 런타임 환경에서 발생하는 Error를 런타임 에러(runtime error) 또는 예외(Exception)라고 부른다.



에러 던지기 throw

try ~ catch를 사용하여 예외(Exception)를 잡아낼 수 있지만 에러 종류와 관계없이 동일한 방식으로 에러를 처리해 주기 때문에 디버깅을 어렵게 만든다.

그러므로 추가적인 자세한 정보를 담은 에러를 만들어야 한다,

사용방식은 아래와 같다.

throw 'errrorrr'; // 던지는 것에 타입 제한은 없으나

throw new Error('throw error'); // 반드시 에러 객체를 던져야 한다.

const e = new Error('숫자가 아니다'); // Error는 어디서나 쓸 수 있는 객체(생성자)이다.


아래처럼 특정 조건에 부합하지 못하면 에러를 던지도록 사용할 수도 있다.
function filterFunc(value) {
if (typeof value === 'number') {
console.log('숫자입니다.');
}
throw new Error('숫자가 아닙니다.');
}

filterFunc('문자를 넣었다.');


인자가 숫자가 아닌 문자인 경우의 결과




마지막으로 finally

finally는 try 블럭안에 에러가 발생하던 안하던 무조건 실행되는 코드이다.

try {
// 수행할 코드

} catch(error) {

// 에러 핸들링

} finally {

// 항상 실행

}


에러가 없다면 : try 블럭 실행 -> finally 실행

에러가 있다면 : try 블럭 실행 -> 에러 발생 -> catch 블럭 실행 -> finally 실행



댓글