JavaBeans 정리

Dion·2020년 3월 4일
1

자바

목록 보기
1/2

JavaBeans 표준

출처

  • EJB(Enterprise Java Beans) 와 혼동해선 안된다.

자바빈즈의 관례

  • 클래스는 직렬화 되어야 한다. (클래스의 상태를 지속적으로 저장 혹은 복원시키기 위해)
    • implements java.io.Serializable
  • 클래스는 기본 생성자를 가지고 있어야한다.
    • public TestClass() {}
  • 모든 property들은 private 해야한다.
  • 클래스의 property 들은 get, set 또는 표준 명명법을 따르는 메소드를 사용해 접근 할 수 있어야 한다.
  • 클래스는 필요한 이벤트 처리 메서드를 포함하고 있어야 한다.
  • boolean 형의 getteris로 시작한다.
  • 영속성이 있어야한다.(?) ⇒ Bean의 현재 상태를 비휘발성의 저장소에 저장하고 나중에 꺼낼 수 있어야 한다.

장점

  • Bean의 속성, 이벤트, 메소드는 다른 애플리케이션에 노출 가능합니다.
  • Bean을 구성하는데 도움이 되는 보조 프로그램이 제공될 수 있습니다.
  • Bean의 설정정보는 영속성 저장소에 저장하고 복원할 수 있습니다.

단점

  • 기본 생성자가 있는 클래스는 유효하지 않은 상태에서 인스턴스화 될 수 있습니다.
    • 수동으로 생성하는 경우 이러한 문제가 생길 수 있습니다.
    • 컴파일러가 이러한 문제를 감지할 수 없습니다.
  • Bean은 기본적으로 변경가능하므로, 불변 객체가 제공하는 이점이 없습니다.
  • 모든 property에 대해 getter를 만들고 대부분의 property에 대해 setter를 만들어야 하는 경우 많은 양의 코드가 생깁니다.
    • Lombok을 이용해서 완화할 수 있습니다.

왜 JavaBeans를 사용하는가?

Java Bean은 Builder Tool에서 시각적으로 조작할 수 있는 재사용 가능한 소프트웨어 컴포넌트입니다.

서로 다른 Builder에서 편리하게 Java Class를 쓸 수 있도록 합니다.

즉, 어디서나 공통의 Convention을 지키며 사용할 수 있는 것이고, 따라서 별도의 문서 없이 쉽고 일관된 방식으로 사용할 수 있음을 의미합니다.

왜 private 한 필드로 이루어져 있는가?

필드에 대한 완벽한 제어를 위함입니다. 또한 Encapsulation을 지키기 위함입니다.

왜 기본 생성자를 사용하는가?

다른 프로그램에서 객체를 생성하려고 하는데, 생성자에 Argument가 존재한다면

Argument가 몇 개인지, 어떤 필드가 필요한지 알아야 합니다.

하지만, Argument가 없다면 어떨까요? 필요한 데이터만 할당해주면 됩니다.

즉, 객체를 런타임(Runtime)에 생성해주는 프로그램이 오브젝트 생성을 하고, getter/setter를 호출해서 할당하도록 하면 Argument에 관여받지 않고, 할당이 가능해집니다.

왜 java.io.Serializable 인터페이스를 구현하여 직렬화하는가?

우리는 데이터를 저장할 수도 있고 다시 읽을 수도 있고, 네트워크로 전송하거나 받아올 수 있습니다.

File I/O, 통신을 할 때, 사용하는 Stream으로 변환을 시켜줘야 하는데, 이 과정을 Serialization이라고 부릅니다.

또한, JavaBean을 왜 사용하는지에 대해서 설명할 때, 서로 다른 Builder에서 편리하게 공통의 Convention을 지키면서 사용하기 위해서 Java Bean을 사용한다고 하였습니다.

즉, JavaBeans는 이러한 과정을 수행할 용도로 Serializable을 구현하도록 사양이 정해졌다고 볼 수 있겠습니다.

profile
코드리뷰와 고양이를 좋아하는 개발자입니다. 좋은 글을 위한 비판은 언제든 환영합니다.

0개의 댓글