Jun4928 / wanted-pre-onboarding-challenge-BE-task-JAN.2023

JAN.2023 wanted 프리온보딩 챌린지 BE 사전과제
29 stars 36 forks source link

사전 과제 제출 #44

Open johnjskim opened 1 year ago

johnjskim commented 1 year ago

1. 본인이 작성했던 코드 중 공유하고 싶은 코드를 이유와 함께 마크다운 code block 을 사용해 올려주세요


#### 간단 로직 설명 및 공유 이유
- db에 존재하는 모든 카테고리(메인카테고리 - 서브카테고리)를 `client`에 전달하기 위해 작성한 파싱함수
- 챌린지 이후 고차함수를 활용 해 조금 더 자바스크립트 다운 코드로 리팩토링 해보고 싶음 

### 2. Layered Architecture(계층 아키텍처)에 대해서 설명해 주세요
#### 계층 아키텍쳐
- S/W 개발에서 가장 일반적으로 사용되는 아키텍처
- 구성되는 계층의 숫자에 따라 N 계층 (N-tier) 아키텍처 라고 함
- 각 계층은 app내에서의 특정 역할 (예: 화면 표시, 비즈니스 로직 수행, DB 통신 등) 별로 구분 됨
- 따라서 특정 계층의 구성요소는 해당 계층에 관련된 기능만 수행
- **장점**:  유지보수와 테스트에 용이

### 3. Dependency Injection(의존성 주입)의 개념과 함께, 왜 필요한지 작성해 주세요
#### 의존성 주입이란?
- 클래스간 의존성을 클래스 외부에서 주입하는 것
  - 클래스에 대한 의존성의 인터페이스화를 통한 코드 유연성 증대 + 클래스의 인스턴스를 외부에서 생성하여 주입

#### 의존성 주입의 필요성
- 클래스간의 결합도가 약해져, 리펙토링과 테스트가 편해진다
- 인터페이스 기반 설계는 코드를 유연하게 하여 확장이 쉬워진다
- UI가 있는 프로그램에서는 생명 주기가 중요한데, 생명주기별로 Container를 관리할 수 있게 된다면 리소스의 낭비를 막을 수 있다.
### 4. 본인이 사용하는 언어의 Functional Programming(함수형 프로그래밍) 스펙을 예제와 함께 소개해 주세요
#### Array.prototype.reduce()
- `arr.reduce(callback[, initialValue])`
- 배열의 각 요소에 대해 주어진 리듀서 (reducer) 함수를 실행하고, 하나의 결과값을 반환

#### 예제
```js
var arr = [1,2,3,4,5,6,7,8,9,10];
arr.reduce(function(prev, cur) {
  return prev + cur;
}); // 55

5. (코드 작성) 다음 스펙을 만족하는 delay 함수를 작성해 주세요 (hint: Promise 사용)

type SomeFunctionReturnString = () => string;

function delay(f: SomeFunctionReturnString, seconds: number): Promise<string> {
  // 해당 함수 내부를 구현해 주세요
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      try {
        resolve(f());
      }catch (e) {
        reject(e);
      }
    }, seconds * 1000);
  });
}

const success = () => {
  return "successfully done";
};

const fail = () => {
  throw new Error("failed");
};

delay(success, 2) // 2초 뒤에 successfully done 로그
  .then((res) => console.log(res))
  .catch((e) => console.log(e));

delay(fail, 2) // 2초 뒤에 failed 로그
  .then((res) => console.log(res))
  .catch((e) => console.log(e));

결과값

    $ ts-node delay.ts
    successfully done
    Error: failed

6. 강의를 통해서 기대하는 바, 또는 얻고 싶은 팁을 적어주세요