2011년 5월 26일 목요일

Encapsulate Collection



컬렉션을 리턴하는 메소드가 있으면 그 메소드가 읽기전용 뷰를 리턴하도록 만들고, add/remove 메소드를 제공하라.

! 동기
  • 클라이언트 코드가 컬렉션을 가지고 있는 클래스가 알지 못하는 사이에 컬렉션의 내용을 조작할 수 없게 해야한다.
  • 클라이언트 코드에 객체의 내부 데이터 구조를 너무 많이 드러내지 않도록 해야 한다.
  • 컬렉션에 대한 set 메소드가 있으면 안된다. 대신 컬렉션에 요소를 추가 삭제하는 오퍼레이션이 있어야 한다.

! 절차
  • (컬렉션을 포함하고 있는 클래스에) 컬렉션에 대한 add/remove 메소드를 추가한다.
  • 필드를 빈 컬렉션으로 초기화한다.
  • set 메소드를 호출하는 코드를 찾는다.
  • set 메소드를 add/remove 오퍼레이션을 사용하도록 수정한다.
  • 또는 클라이언트 코드가 set 메소드 대신 오퍼레이션을 호출하도록 수정한다.
  • get메소드를 사용하여 컬렉션을 수정하는 코드를 찾아서 add/remove메소드를 사용하도록 수정한다. 각각의 변경에 대해 컴파일, 테스트를 한다.
  • get 메소드를 사용하여 컬렉션을 수정하는 코드를 모두 바꾸었으면, get 메소드가 컬렉션의 읽기전용 뷰를 리턴하도록 수정한다.
  • get 메소드를 사용하는 코드를 찾는다. 호스트 객체에 있어야 하는 코드가 있는지 본다. Extract Method와 Move Method를 사용하여 코드를 호스트 객체로 옮긴다.
    TIP
    자바 1.1에서는 클라이언트가 Enumeration을 사용하는 것이 좋다.
    • 현재의 get 메소드의 이름을 바꾸고 Enumeration을 리턴하는 새로운 get 메소드를 추가한다.
    • 예전의 get 메소드를 사용하는 코드를 찾아 새로운 메소드를 사용하도록 수정한다.

댓글 없음:

댓글 쓰기

블록체인 개요 및 오픈소스 동향

블록체인(block chain) 블록체인은 공공 거래장부이며 가상 화폐로 거래할때 발생할때 발생할 수 있는 해킹을 막는 기술. 분산 데이터베이스의 한 형태로, 지속적으로 성장하는 데이터 기록 리스트로서 분산 노드의 운영자에 의한 임의 조작이 불가...