개발로그

Item 87 - 커스텀 직렬화 형태를 고려하라

클래스가 Serializable을 구현하고 기본 직렬화 형태를 사용한다면 다음 릴리스 때 버리려 한 현재의 구현에 발이 묶이게 된다. 먼저 고민해보고 괜찮다고 판단될 때만 기본 직렬화 형태를 사용하라. 기본 직렬화 형태는 유연성, 성능, 정확성 측면에서 신중히 고민한 후 합당할 때만 사용해야 한다. 객체의 물리...

Item 85 - 자바 직렬화의 대안을 찾아라

직렬화 객체 직렬화 : 자바가 객체를 바이트 스트림으로 인코딩(직렬화)하고, 그 바이트 스트림으로부터 다시 객체를 재구성(역직렬화)하는 매커니즘이다. 직렬화된 객체는 다른 VM에 전송하거나 디스크에 저장한 후 필요할 때 역직렬화하여 사용할 수 있다. 자바의 직렬화 “자바의 직렬화는 위험하다.” 보이지 않는 생성자, API와 구...

Item 84 - 프로그램의 동작을 스레드 스케줄러에 기대지 말라

이식성을 높이는 방법 정확성이나 성능이 스레드 스케줄러에 따라 달라지는 프로그램이라면 다른 플랫폼에 이식하기 어렵다. 🤦 (1) 실행 가능한 스레드의 평균적인 수를 프로세스 수보다 지나치게 많아지지 않도록 하라. 그래야 스케줄러가 고민할 거리가 줄어든다. 실행 준비가 된 스레드들은맡은 작업을 완료할 때까지 계속 실행되도록 만들어라...

Item 83 - 지연 초기화는 신중히 사용하라

지연 초기화 (lazy initialization) 🐢 필드의 초기화 시점을 그 값이 처음 필요할 때까지 늦추는 기법 정적 필드와 인스턴스 필드에 모두 사용가능 주로 최적화 용도로 쓰이지만, 클래스와 인스턴스 초기화 때 발생하는 위험한 순환 문제를 해결하는 효과도 있다. 지연 초기화는 필요할 때까지는 하지 말라 🙅 클래스나 인...

Item 82 - 스레드 안전성 수준을 문서화하라

여러 스레드가 하나의 메서드를 동시에 호출할 때 그 메서드가 어떻게 동작하느냐는 클라이언트와 클래스 간의 중요한 계약과도 같다. 만약 API 문서에 아무런 언급이 없다면 사용자는 나름의 가정을 하고 사용해야 한다. 만약 이 가정이 틀린다면 프로그램은 심각한 오류로 이어질 수 있다. 😰 API 문서에 synchronized 한정자 synchro...

Item 76 - 가능한 한 실패 원자적으로 만들라

실패 원자성(Failure Atomicity) 호출된 메소드가 실패하더라도 해당 객체는 메서드 호출 전 상태를 유지해야 한다. 위와 같은 특성을 실패 원자성이라고 한다. 실패 원자성은 시스템의 안정성, 성능, 신뢰성을 향상시키는데 필수적이다. 메서드 실패 원자적으로 만드는 방법 방법 1 : 불변 객체로 설계하기 - item17...