-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Week1] 멋사 레스토랑 #2
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
사장님~ 제가 고수 빼달라고 했잖아요~
너무 잘하셨습니다!
다만, 조금 더 개선할 여지가 있는 부분을 드리자면 입력과 출력, 데이터 처리부분이 조금 결합되어있는 모습을 확인 할 수 있었는데요, 이부분을 좀 더 분리해보는건 어떨까 싶습니다.
이 부분이 붙어있게되면, 입출력 명세가 바뀐다던지 하는경우가 생길때 수정할 부분들이 많아지거든요!
그리고 파일로 분리해보는건 어떨까요?
sanghyun/week1.js
Outdated
const Status={ | ||
WAITING: 0, | ||
COOKING: 1, | ||
COOKED: 2, | ||
SERVING: 3, | ||
SERVED: 4, | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
혹시 Status가 변경될 수 있는 위험을 줄이기 위해 얼리기를 추천드립니다!
const STATUS=Object.freeze({
WAITING: 0,
COOKING: 1,
COOKED: 2,
SERVING: 3,
SERVED: 4,
});
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
반영했습니다!
sanghyun/week1.js
Outdated
this.chefQueue = []; | ||
this.serverQueue = []; | ||
this.finishedQueue = []; | ||
this.isCooking = false; | ||
this.isServing = false; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
지금도 너무 좋지만, 조금 개선할 여지가 있는부분을 말씀드리자면
레스토랑이 셰프 큐와 서버큐, 완료 큐, 그리고 요리 상태와 서빙 상태를 갖고 있네요. 레스토랑이 모든 정보를 다 갖게 되는데 이로인해서 이후에 유지보수, 기능추가에 문제가 생길 수도 있을 것 같습니다.
예를들어서 셰프가 한명 더 생긴다던지, 서버가 한명 더생기는 경우이죠.
이런경우를 고려해서 역할을 조금 더 분리 해보는 건 어떨까요?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
코멘트대로 추가 구현했습니다! 확인 부탁드려요!
Node Conference - Week1 HW
설계:
EventEmitter
를 호출해 각 큐를 진행 시킵니다.EventEmitter()
인스턴스가 호출한 이벤트만 listen할 수 있어, 공통 인스턴스를 선언한 후 export 했습니다.chooseChef()
와chooseServer()
에 로드 밸런싱을 위임했고, 각 1명의 요리사/홀알바를 데리고 있는 것으로 가정해 구현했습니다.emitter
선언부를 수정한 커밋이 PR에 안뜨네요..const
선언으로 수정했습니다..!결과:
[개선]
data:image/s3,"s3://crabby-images/e501a/e501a2f4fe4ab4c18e515316b94991a13c6e394f" alt="image"