개요
싱글톤 패턴은 클래스의 인스턴스화를 단일 인스턴스로 제한하는 소프트웨어 디자인 패턴입니다. '인스턴스'는 프로그래밍 언어마다 지칭하는 표현이 약간 다르지만 일반적으로 정의한 클래스를 현실화한(realized) 객체를 의미합니다. '인스턴스화'는 정의한 클래스 현실화를 의미합니다.
인스턴스화한 단일 인스턴스 하나를 계속 재사용하는 방식입니다. 주로 프로그램 전반에 전역으로 사용해야 하는 경우 싱글톤 패턴을 활용할 수 있습니다.
구현
코틀린에서는 object 키워드를 사용하여 싱글톤 패턴 클래스를 작성할 수 있습니다.
object DataProviderManager {
fun registerDataProvider(provider: DataProvider) {
// ...
}
val allDataProviders: Collection<DataProvider>
get() = // ...
}
인스턴스를 사용하고자 할 때 아래와 같이 사용할 수 있습니다.
DataProviderManager.registerDataProvider(...)
한계
싱글톤 패턴은 일반적으로 전역적으로 활용해야 하는 경우 적용하여 사용 메모리를 줄일 수 있습니다.(인스턴스를 매번 클론하지 않아 많은 메모리를 잡아먹지 않기 때문에) 그러나 싱글톤 패턴은 항상 모든 상황에 적절한 디자인 패턴은 아닙니다. 싱글톤 패턴은 아래와 같은 문제점들을 가지고 있습니다.
- 멀티쓰레드 환경에서의 동시성 문제 (코틀린 object키워드는 이 문제를 해결했습니다.)
- 싱글톤 패턴 인스턴스가 비대해지는 경우 프로그래밍 디자인이 꼬이는 문제
- 수정과 테스트가 어려움 (유닛 테스트 난이도가 매우 높습니다.)
특히 유닛 테스트 시 서로 독립적인 mock 객체를 생성하는 mocking은 테스트를 위한 핵심 과정인데, 단일 인스턴스여야 하는 싱글톤 패턴 인스턴스를 서로 독립적인 mock 객체로 생성하여 mocking한다..? 많이 이상합니다.
유닛 테스트는 TDD에 핵심입니다. 이를 포기하고 싱글톤 패턴을 적용하는 것이 맞는 지는.. 많은 고민이 필요해 보입니다.
출처
'컴퓨터공학 & 정보통신' 카테고리의 다른 글
[운영체제] 멀티 스레드(Multi-Thread)에 대한 이해 (0) | 2023.08.10 |
---|---|
[디자인패턴] 어댑터(Adapter) 패턴에 대한 이해 (0) | 2023.08.09 |
[알고리즘/기초] 피보나치 수 (0) | 2023.08.05 |
[머신러닝] Unsupervised Learning (0) | 2023.06.12 |
[머신러닝] Model Selection (0) | 2023.06.12 |