>웹 프론트엔드 >JS 튜토리얼 >JavaScript 클로저: 주요 인터뷰 질문 및 답변

JavaScript 클로저: 주요 인터뷰 질문 및 답변

Linda Hamilton
Linda Hamilton원래의
2024-11-09 00:43:021027검색

JavaScript Closures: Top Interview Questions and Answers

JavaScript 클로저: 주요 인터뷰 질문 및 답변.

1. JavaScript의 클로저란 무엇입니까?

정답:
JavaScript에서는 내부 함수가 외부 함수 내에 정의되고 외부 함수의 변수 및 매개변수에 액세스할 때 클로저가 생성됩니다. 외부 함수의 실행이 완료된 후에도 내부 함수는 해당 변수에 대한 액세스를 유지합니다.

2. JavaScript에서 클로저가 중요한 이유는 무엇입니까?

정답:
클로저는 데이터 캡슐화 및 기능 개인 정보 보호를 허용하므로 JavaScript에서 중요합니다. 이는 깨끗한 전역 범위를 유지하는 데 도움이 되며 외부에서 액세스할 수 없는 전용 변수 생성을 가능하게 합니다. 이는 객체 지향 프로그래밍의 기본 측면입니다.

3. JavaScript에서 클로저의 예를 들어주실 수 있나요?

정답:

function outerFunction() {
  var outerVariable = "Hello, ";
  function innerFunction(name) {
    console.log(outerVariable + name);
  }
  return innerFunction;
}
var inner = outerFunction();
inner("John"); // Output: "Hello, John"

이 예에서 innerFunction은 externalFunction이 실행을 마친 후에도 externalFunction에 정의된 externalVariable에 액세스할 수 있으므로 클로저입니다.

4. JavaScript에서 클로저를 어떻게 사용합니까?

정답:
JavaScript에서는 외부 함수 내에 내부 함수를 정의하고 내부 함수를 반환하여 클로저를 사용합니다. 내부 함수는 외부 함수 실행이 완료된 후에도 외부 함수의 변수 및 매개변수에 대한 액세스를 유지합니다.

5. 다음 코드의 출력은 무엇입니까?

function outer() {
  var x = 10;
  function inner() {
    console.log(x);
  }
  return inner;
}
var innerFunc = outer();
innerFunc();

정답:
출력: 10
설명: 외부 함수는 내부를 반환하고 내부는 외부 내부에 선언된 변수 x에 액세스할 수 있습니다. innerFunc가 호출되면 x(10)를 기록합니다.

6. 다음 코드의 출력은 무엇입니까?

function outer() {
  var x = 10;
  function inner() {
    console.log(x);
  }
  x = 20;
  return inner;
}
var innerFunc = outer();
innerFunc();

정답:
출력: 20
설명: x 값은 inner가 반환되기 전에 20으로 업데이트됩니다. innerFunc가 호출되면 업데이트된 x 값인 20을 기록합니다.

7. 다음 코드의 출력은 무엇입니까?

function outer() {
  var x = 10;
  function inner() {
    var y = 5;
    console.log(x + y);
  }
  return inner;
}
var innerFunc = outer();
innerFunc(); // Output: 15

정답:
출력: 15
설명: 내부는 외부 함수의 x(10)와 자체 범위의 y(5)에 모두 액세스할 수 있으므로 출력은 15입니다.

8. 다음 코드의 출력은 무엇입니까?

function outer() {
  var x = 10;
  function inner() {
    var y = 5;
    console.log(x + y);
  }
  var x = 20;
  return inner;
}
var innerFunc = outer();
innerFunc();

정답:
출력: 25
설명: 변수 x는 내부 함수가 반환되기 전에 외부 함수 내부에서 20에 다시 할당됩니다. innerFunc가 호출되면 20 5 = 25인 x y를 기록합니다.

9. 다음 코드의 출력은 무엇입니까?

function outerFunction() {
  var outerVariable = "Hello, ";
  function innerFunction(name) {
    console.log(outerVariable + name);
  }
  return innerFunction;
}
var inner = outerFunction();
inner("John"); // Output: "Hello, John"

정답:
출력:
첫 통화: 15
두 번째 통화: 25

설명: 첫 번째 호출에서 x는 10이고 y는 5이므로 출력은 15입니다. x를 20으로 업데이트한 후 두 번째 호출에서는 20 5, 즉 25를 기록합니다.

10. JavaScript에서 클로저를 언제 사용해야 합니까?

정답:
비공개 상태를 유지해야 하거나 전역 범위에서 액세스할 수 없는 변수를 캡슐화해야 할 때 클로저를 사용합니다. 특히 특정 변수에 대한 액세스를 제한하고 해당 변수에 액세스하거나 수정할 수 있는 범위를 제어하려는 상황에서 데이터 개인 정보 보호를 생성하는 데 유용합니다.

11. 클로저와 콜백이란 무엇입니까?

정답:
클로저와 콜백은 JavaScript에서 서로 다른 두 가지 개념입니다. 클로저는 생성된 환경을 기억하는 함수이며 해당 함수가 반환된 후에도 외부 함수의 변수에 액세스할 수 있습니다. 반면 콜백은 다른 함수에 인수로 전달되는 함수이며 외부 함수가 완료된 후에 실행됩니다.

12. 폐쇄의 두 가지 유형은 무엇입니까?

정답:
JavaScript에는 어휘 클로저와 동적 클로저라는 두 가지 유형의 클로저가 있습니다. 어휘 클로저는 컴파일 시간에 생성되며 어휘 범위의 변수에 액세스할 수 있는 반면, 동적 클로저는 런타임에 생성되고 동적 범위의 변수에 액세스할 수 있습니다.

13. Lambda는 클로저와 동일합니까?

**정답:*
JavaScript에서 람다 함수는 이름 없이 즉석에서 생성되는 익명 함수입니다. 반면에 클로저는 외부 함수가 반환된 후에도 외부 함수의 변수에 대한 액세스를 유지하는 함수입니다. 람다 함수는 클로저를 생성할 수 있지만 동일하지는 않습니다.

14. 커링과 클로저의 차이점은 무엇입니까?

정답:
커링은 여러 인수를 취하는 함수를 각각 하나의 인수를 취하는 일련의 함수로 변환하는 프로세스입니다. 반면에 클로저는 외부 함수 범위에서 변수에 접근할 수 있는 함수입니다. 커링에서는 클로저를 사용할 수 있지만 개념이 다릅니다.

15. 폐쇄는 캡슐화와 동일합니까?

정답:
클로저와 캡슐화는 서로 관련되어 있지만 동일하지는 않습니다. 캡슐화는 데이터와 해당 데이터를 단일 단위(주로 클래스) 내에서 작동하는 메서드를 묶고 개체의 일부 구성 요소에 대한 액세스를 제한하는 개념을 나타냅니다. 클로저에는 외부 함수의 변수에 액세스하는 함수가 포함되며, 클로저는 데이터를 캡슐화하는 데 사용될 수 있지만 캡슐화와 동의어는 아닙니다.

16. JavaScript는 중첩 함수를 지원합니까? 어떻게 작동하나요?

정답:
예, JavaScript는 중첩 함수를 지원합니다. 중첩 함수는 다른 함수 내부에 정의되며 외부 함수의 변수 및 매개변수에 액세스할 수 있습니다. 이를 통해 클로저, 캡슐화 및 모듈식 코드 구조가 가능합니다.

function outerFunction() {
  var outerVariable = "Hello, ";
  function innerFunction(name) {
    console.log(outerVariable + name);
  }
  return innerFunction;
}
var inner = outerFunction();
inner("John"); // Output: "Hello, John"

17. JavaScript의 어휘 환경(Lexical Environment)이 무엇인지 설명해 주실 수 있나요?

정답:
JavaScript에서 어휘 환경은 특정 범위 내의 값에 대한 변수 바인딩, 함수 및 기타 참조를 보유하는 구조입니다. 이는 JavaScript 실행 컨텍스트의 핵심 부분이며 런타임 중에 변수에 액세스하고 해결하는 방법을 결정하는 데 도움이 됩니다.

18. 가비지 수집은 JavaScript의 어휘 환경 및 중첩 함수에서 어떻게 작동합니까?

정답:
JavaScript에서 가비지 수집은 더 이상 필요하지 않은 개체가 사용하는 메모리를 회수하는 프로세스입니다. 함수가 생성되고 클로저가 형성되면 변수에 대한 참조를 저장하는 어휘 환경으로 인해 클로저가 더 이상 사용되지 않을 때까지 메모리가 수집되지 않을 수 있습니다.

function outer() {
  var x = 10;
  function inner() {
    console.log(x);
  }
  return inner;
}
var innerFunc = outer();
innerFunc();

19. JavaScript 클로저의 일반적인 사용 사례는 무엇입니까?

정답:
클로저의 일반적인 사용 사례에는 데이터 캡슐화, 함수 팩토리, 메모, 데코레이터 구현, 비동기 프로그래밍의 상태 유지 등이 있습니다.

20. JavaScript에서 클로저를 사용하면 어떤 이점이 있나요?

정답:
JavaScript의 클로저는 개인 정보 보호, 함수 팩토리, 함수 호출 간 상태 유지 기능과 같은 여러 가지 이점을 제공합니다. 더욱 강력하고 유지 관리가 용이한 모듈식 코드를 허용하고 JavaScript의 기능적 프로그래밍 패러다임을 지원합니다.

21. JavaScript에서 클로저를 사용할 때 단점이나 함정은 무엇입니까?

정답:
클로저를 사용하면 클로저가 제대로 관리되지 않으면 메모리 누수, 메모리에 원치 않는 변수 참조가 유지되거나 의도하지 않은 외부 변수가 실수로 수정되는 등의 잠재적 위험이 발생할 수 있습니다.

22. 클로저는 JavaScript의 가비지 수집 메커니즘에 어떤 영향을 줍니까?

정답:
클로저는 외부 함수 실행이 완료된 후에도 메모리에 변수에 대한 참조를 유지하여 가비지 수집에 영향을 줍니다. 이렇게 하면 클로저가 더 이상 필요하지 않은 개체에 대한 참조를 보유하는 경우 가비지 수집으로 인해 메모리가 확보되는 것을 방지할 수 있습니다.

? LinkedIn에서 나와 연결하세요:

소프트웨어 엔지니어링의 세계로 함께 더 깊이 들어가 보세요! 저는 JavaScript, TypeScript, Node.js, React, Next.js, 데이터 구조, 알고리즘, 웹 개발 등에 대한 통찰력을 정기적으로 공유합니다. 기술을 향상하고 싶거나 흥미로운 주제에 대해 공동작업을 하고 싶다면, 저는 여러분과 소통하고 성장하고 싶습니다.

팔로우: 노지불 이슬람

위 내용은 JavaScript 클로저: 주요 인터뷰 질문 및 답변의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.