[45] 메서드가 실패했음을 알리기 위해서 예외를 이용하라

다음 본문은 도서 이펙티브 C# (빌 와그너)에서 나오는 주제를 다룹니다.

 

 

반환코드

반환코드의 경우 메서드의 원형에 영향을 미친다. 계산의 결과를 나타내는 용도로 사용되므로 오류가 발생했다는 사실 이외의 추가적인 정보를 전달하기가 어렵다.

메서드 호출자에 의해서 처리된다.

 

예외

예외를 이용하는 방식은 클래스 타입이므로 개발자가 자신만의 예외 타입을 파생시킬 수 있으며 오류에 대한 추가적인 정보를 전달할 수 있다. 

콜 스택을 통해서 적절한 catch문이 구성된 위치까지 전파된다.

적절한 catch문이 포함되어있지 않다면 응용프로그램이 종료되니 예외는 쉽게 무시하기 어렵다.

 

사전에 예외 검사하기

예외를 처리하는 작업은 일반적인 메서드 호출보다 시간이 많이 걸린다. 특정 작업을 수행하기 전에 실패할 가능성이 있는지 확인하는 편이 좋다.

// 이런 방법은 사용하지 말라.
DoesWorkThatMightFail worker = new DoesWorkThatMightFail();
try
{
    worker.DoWork();
}
catch(WorkerException e)
{
    ReportErrorToUser("테스트 실패");
}

예외를 발생시키는 메서드를 작성할 때는 항상 예외를 유발하는 조건을 사전에 검사할 수 있는 메서드를 함께 작성할 것을 권장한다.

public class DoesWorkThatMightFail
{
    public bool TryDoWork()
    {
        if(!TestConditions())
            return false;
            
        Work(); // 여전히 실패할 가능성은 있지만 낮다.
        return true;
    }
    
    public void DoWork => Work();
    
    private bool TestConditions()
    {
        //...
        return true;
    }
    
    private void Work()
    {
        //...
    }
}

위와 같이 작성하면 예외가 발생할 가능성이 있는 메서드를 호출하기 이전에 사전 조건을 테스트해볼 수 있으므로 예외로 인한 성능 저하를 피할 수 있다.

 

결론

 메서드가 실패했을 때는 언제나 예외를 발생시키는 것이 좋지만, 일반적인 흐름 제어 메커니즘으로 사용해서는 안된다.

 또한 사전에 테스트할 수 있는 메서드를 같이 제공하는 것이 좋다.

 

 

댓글

Designed by JB FACTORY