기록이 힘이다.

[이펙티브 자바] 아이템76 가능한 한 실패 원자적으로 만들라 본문

JAVA

[이펙티브 자바] 아이템76 가능한 한 실패 원자적으로 만들라

dev22 2023. 4. 30. 18:28
728x90

일반화해 이야기하면, 호출된 메서드가 실패하더라도 해당 객체는 메서드 호출 전 상태를 유지해야 한다. => 실패 원자적(failure-atomic)

실패 원자적으로 만드는 방법 

1. 불변 객체로 설계하는 것이다.=> 태생적으로 실패 원자적

2. 가변 객체의 메서드를 실패 원자적으로 만드는 가장 흔한 방법은 작업 수행에 앞서 매개변수의 유효성을 검사하는 것이다. 객체의 내부 상태를 변경하기 전에 잠재적 예외의 가능성 대부분을 걸러낼 수 있는 방법이다. ex) TreeMap

public Object pop(){
  if(size ==0)
  	throw new EmptyStackException();
  Object result = elements[--size];
  elements[size] = null; // 다 쓴 참조 해제
  return result;
}

3. 객체의 임시 복사본에서 작업을 수행한 다음, 작업이 성공적으로 완료되면 원래 객체와 교체하는 것이다. 데이터를 자료구조에 저장해 작업하는 게 더 빠를 때 적용하기 좋은 방식이다.

4. 작업 도중 발생하는 실패를 가로채는 복구 코드를 작성하여 작업 전 상태로 되돌리는 방식이다. 주로 내구성 보장하는 자료구조, 자주쓰이는 방법 X

 

실패 원자성은 일반적으로 권장되는 덕목이지만 항상 달성할 수 있는 것은 아니다

 

실패 원자적으로 만들 수 있더라도 항상 그리 해야 하는 것도 아니다. 실패 원자성을 달성하기 위한 비용이나 복잡도가 아주 큰 연산도 있기 때문이다.

 

메서드 명세에 기술한 예외라면 설혹 예외가 발생하더라도 객체의상태는 메서드 호출 전과 똑같이 유지돼야 한다는 것이 기본 규칙이다.