inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

CS 지식의 정석 | 디자인패턴 네트워크 운영체제 데이터베이스 자료구조

팩토리패턴 ★★★

팩토리 패턴 상속관계

409

섬세한 햄스터

작성한 질문수 10

0

안녕하세요 큰돌님! 항상 좋은 강의 감사합니다.

팩토리패턴 강의를 수강하다가 궁금한 점이 생겨 질문드립니다.

 

팩토리패턴 javascript 예제에서 CoffeeFactory가 중요한 뼈대를 결정하는 상위 클래스, LatteFactory, EspressoFactory가 객체 생성 방식을 결정하는 하위 클래스로 이해를 했는데 굳이 LatteFactory와 EspressoFactory가 CoffeeFactory를 상속받는 이유가 있나요..?

 

팩토리 패턴은 "상속관계에 있는" 두 클래스에서 상위 클래스가 중요한 뼈대를 결정하고, 하위클래스에서 객체 생성에 관한 구체적인 내용을 결정하는 패턴이라고 하셨는데 위와 같은 이유로 정의와 예제가 다른 부분이 있는 같아서 질문드립니다. 제가 예제를 잘못이해한 건가요.. ㅠㅠ

면접 운영체제 기술면접

답변 1

1

큰돌

안녕하세요 햄스터님 ㅎㅎ

아이디 정말 이쁘네요 ㅎㅎ

 

팩토리패턴 javascript 예제에서 CoffeeFactory가 중요한 뼈대를 결정하는 상위 클래스, LatteFactory, EspressoFactory가 객체 생성 방식을 결정하는 하위 클래스로 이해를 했는데 굳이 LatteFactory와 EspressoFactory가 CoffeeFactory를 상속받는 이유가 있나요..?

>>

class CoffeeFactory {
    static createCoffee(type) {
        const factory = factoryList[type]
        return factory.createCoffee()
    }
}   
class Latte {
    constructor() {
        this.name = "latte"
    }
}
class Espresso {
    constructor() {
        this.name = "Espresso"
    }
} 

class LatteFactory extends CoffeeFactory{
    static createCoffee() {
        return new Latte()
    }
}
class EspressoFactory extends CoffeeFactory{
    static createCoffee() {
        return new Espresso()
    }
}
const factoryList = { LatteFactory, EspressoFactory } 
 
 
const main = () => {
    // 라떼 커피를 주문한다.  
    const coffee = CoffeeFactory.createCoffee("LatteFactory")  
    // 커피 이름을 부른다.  
    console.log(coffee.name) // latte
}
main()

이부분이죠?

상위 : 커피팩토리

하위 : 라떼, 에스프레소

이죠?

여기서 왜 extends를 써서 상속을 시켰냐는 말씀이신데요.

상속을 사용하게 되면 상위, 하위 클래스인게 명시적인게 되면서도.

상위클래스의 메서드를 사용할 수 있거나 해당 메서드를 오버라이드 해서 쓸 수 있는 장점이 있기 때문에 쓰는 것입니다.

class A  {
    static func() {
        console.log(1) 
    }
}   
class B extends A { 

}    
const main = () => {  
    B.func() 
}
main()

이렇게 하시면 B에 func를 선언을 하지 않아도 1이 찍히게 됩니다.

 

 

팩토리 패턴은 "상속관계에 있는" 두 클래스에서 상위 클래스가 중요한 뼈대를 결정하고, 하위클래스에서 객체 생성에 관한 구체적인 내용을 결정하는 패턴이라고 하셨는데 위와 같은 이유로 정의와 예제가 다른 부분이 있는 같아서 질문드립니다. 제가 예제를 잘못이해한 건가요.. ㅠㅠ

>> 예제와 설명은 같습니다.

이렇게 되는 것이죠.

 

image

 

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

 

0

섬세한 햄스터

답변 감사합니다!

제가 질문을 애매하게 했더군요.. 죄송합니다ㅠㅠ

제가 궁금한 부분은 extends를 써서 상속을 시키지 않더라도 잘 작동하는 코드인데 굳이 extends를 써서 상속을 시킨 이유가 궁금했습니다.

 

그리고 만약 extends로 상속을 시키지 않았다면 팩토리 패턴이 아닌건가요?

팩토리 패턴은 "상속관계에 있는" 두 클래스에서 상위 클래스가 중요한 뼈대를 결정하고, 하위클래스에서 객체 생성에 관한 구체적인 내용을 결정하는 패턴인데, 상속관계에 있지 않으니까요!

1

큰돌

아아... 그런 의미셨군요 ㅎㅎ

extends를 써야 상속의 의미를 갖게 됩니다.

 

그리고 만약 extends로 상속을 시키지 않았다면 팩토리 패턴이 아닌건가요?

>> 엄밀히 따지면 그렇습니다.

음.. 사실 코드를 보았을 때 상속인게 보이면 상속이라고도 볼 수 있지만..

엄밀히 따지면

상속을 나타내주는 키워드를 써주어야 합니다.

javascript 기준. 클래스를 기반으로 상속을 나타내려면 extends를 쓰거나 prototype를 이용해서 상속을 걸어주어야 합니다 .

 


또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

REST API (Self-descriptive messages)

0

28

1

시스템 엔지니어 관련 질문입니다.

0

53

2

오버라이딩 관련하여 질문드립니다.

0

62

2

교착상태의 4가지 필요조건이 필요충분조건이 아닌 이유

0

91

1

렌더 트리, 렌더 레이어와 그래픽 레이어

0

57

2

로컬스토리지, 세션스토리지, 쿠키의 공통점

0

68

1

IPv4가 IPv6보다 빠른 경우

0

103

2

UDP가 전송계층의 역할을 못하는 건 아닌지

0

59

1

Path MTU 발견하였음에도 패킷 분할이 필요한 이유?

0

65

2

교재의 LFU 알고리즘에서 6번이 왜 히트인가요?

0

64

2

페이지 교체 알고리즘? 프레임 교체 알고리즘?

0

83

2

Static 키워드가 메모리에 올라가는 시점

0

78

2

헤더 압축부분 질문드립니다

0

73

2

공유 캐시 관련 질문 드립니다.

0

56

2

컨텍스트는 context와 contextual information으로 나눠진다는게 무슨뜻인가요?

0

201

1

회선과 대역폭의 관계

0

62

2

44강 질문

0

95

2

버스 토폴로지 질문 있씁니다

0

55

1

자바스크립트, xml 문법 관련

0

67

2

전략패턴과 의존성주입 질문

0

69

2

Model이 비즈니스 로직을 담당하나요?

0

107

2

CS 공부 하는 법

0

181

2

큰돌님 블로그에 개념정리해서 올려도될까요!

0

137

2

FIN 세그먼트 질문

0

72

2