인프런 커뮤니티 질문&답변
안녕하세요. 문의드립니다.
작성
·
58
·
수정됨
0
직접 구현하는 Set1 - MyHashSetV1 강의중
public class MyHashSetV1 {
static final int DEFAULT_INITIAL_CAPACITY = 16;
LinkedList<Integer>[] buckets;
private int size = 0;
private int capacity = DEFAULT_INITIAL_CAPACITY;
public MyHashSetV1() {
buckets = new LinkedList[capacity];
for (int i = 0; i < capacity; i++) {
buckets[i] = new LinkedList<>();
}
}이렇게 생성자에 객체를 생성하는데
클래스 필드에 객체를 생성하지 않고
생성자 안에서 생성하는 이유가 무엇인지 궁금해서 문의드립니다.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
kss8014님이 질문해주신 “클래스 필드에 객체를 생성하지 않고 생성자 안에서 생성하는 이유”에 대해 설명해 드리겠습니다.
생성자에서 객체를 생성하는 이유
초기화 로직의 중앙집중화:
- 생성자를 사용하여 객체를 초기화하면, 초기화 로직을 한 가지 장소(생성자)에 집중시킬 수 있습니다. 이는 유지보수성과 가독성을 높이는 데 도움을 줍니다. 만약 여러 생성자를 추가할 경우라도, 초기화 관련 코드를 변경해야 할 때 각 생성자에 대한 중복작업을 줄일 수 있습니다.
- 생성자를 사용하여 객체를 초기화하면, 초기화 로직을 한 가지 장소(생성자)에 집중시킬 수 있습니다. 이는 유지보수성과 가독성을 높이는 데 도움을 줍니다. 만약 여러 생성자를 추가할 경우라도, 초기화 관련 코드를 변경해야 할 때 각 생성자에 대한 중복작업을 줄일 수 있습니다.
의존성 설정 가능:
- 생성자 내부에서는 다른 객체나 변수를 사용하는 초기화 로직을 쉽고 유연하게 구현할 수 있습니다. 예를 들어, 생성자 파라미터를 기반으로 필드의 초기 상태를 결정할 수 있습니다. 이는 객체 초기화에 있어 유연성과 다형성을 제공합니다.
- 생성자 내부에서는 다른 객체나 변수를 사용하는 초기화 로직을 쉽고 유연하게 구현할 수 있습니다. 예를 들어, 생성자 파라미터를 기반으로 필드의 초기 상태를 결정할 수 있습니다. 이는 객체 초기화에 있어 유연성과 다형성을 제공합니다.
성능상의 이점:
- 클래스 필드에서 직접 객체를 생성하는 경우, 모든 인스턴스가 같은 초기화 로직을 따르게 됩니다. 반면, 생성자에서는 조건에 따라 객체를 초기화할 수 있으므로, 보다 효과적으로 메모리를 사용할 수 있습니다. 이는 불필요한 객체 생성을 피할 수 있게 합니다.
- 클래스 필드에서 직접 객체를 생성하는 경우, 모든 인스턴스가 같은 초기화 로직을 따르게 됩니다. 반면, 생성자에서는 조건에 따라 객체를 초기화할 수 있으므로, 보다 효과적으로 메모리를 사용할 수 있습니다. 이는 불필요한 객체 생성을 피할 수 있게 합니다.
이와 같은 이유들로 인해, 클래스 필드에 객체를 생성하지 않고 생성자 내에서 객체를 초기화하는 것이 좋습니다. 클래스를 사용하는 시점에 필요에 맞게 초기화할 수 있어 코드 효율성을 높입니다.
이와 관련하여 추가적인 논의는 다음 링크에서 찾아보실 수 있습니다:
- “연결리스트 배열 선언?” 관련 Q&A
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





