일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- docker
- AZ-900
- DevOps
- FastAPI
- Django
- Python
- AZ-104
- asyncio
- dockerfile
- EKS
- event loop
- leetcode
- Service
- 자바스크립트
- Network
- IAC
- EC2
- AZURE
- asgi
- ebs
- POD
- Kubernetes
- AWS
- ansible
- terraform
- WSGI
- elasticsearch
- K8S
- Deployment
- 쿠버네티스
- Today
- Total
목록전체 글 (174)
궁금한게 많은 개발자 노트
let과 const는 ES2015(ES6)에 추가된 변수 선언 키워드 hoisting규칙이 없고, block scoping을 지원함 -> 따라서 var 보다 훨씬 예측 가능한 코드 작성 가능 let은 레퍼런스가 바뀔 수 있음, const는 바뀔 수 없음 -> var는 재 선언이 가능하지만, let과 const는 불가 var와는 달리 let과 const는 hoisting기능이 없기 때문에 선언 전에 사용할 수 없음 (선언 후 사용) let과 const는 모두 같은 scoping rule을 따름 (let과 const의 예측 가능성과 유지보수성이 var보다 훨씬 뛰어남) 가능하다면 const만 사용하고, 필요한 경우에 한해 let을 쓰고, var는 절때 사용X let의 사용하는 경우는 closure를 사용하여..
Java, C++과 같은 클래스 기반 객체지향 프로그래밍 언어와 달리 자바스크립트는 프로토타입 기반 객체지향 프로그래밍 언어이다. 따라서 자바스크립트의 동작 원리를 이해하기 위해서는 프로토타입의 개념을 잘 이해하고 있어야 한다. 클래스 기반 객체지향 프로그래밍 언어는 객체 생성 이전에 클래스를 정의하고 이를 통해 객체(인스턴스)를 생성한다. 하지만 프로토타입 기반 객체지향 프로그래밍 언어는 클래스 없이(Class-less)도 (ECMAScript 6에서 클래스가 추가되었다) 객체를 생성할 수 있다. 생성자 예시) 참고 function Person(name, gender) { var married = true; // private this.name = name; // public this.gender = ..
구글의 Chrome V8 자바스크립트 엔진으로 빌드된 자바스크립트 런타임 환경(Runtime Environment)인 Node.js의 등장으로 자바스크립트는 웹 브라우저를 벗어나 서버 사이드 애플리케이션 개발에서도 사용되는 범용 개발 언어가 되었다. 하지만 자바스크립트가 가장 많이 사용되는 분야는 역시 웹 브라우저 환경에서 동작하는 웹 페이지/애플리케이션이다. 대부분의 프로그래밍 언어는 운영체제(Operating System, OS) 위에서 실행되지만 웹 애플리케이션의 자바스크립트는 브라우저에서 HTML, CSS와 함께 실행된다. 따라서 브라우저 환경을 고려할 때 보다 효율적인 자바스크립트 프로그래밍이 가능하다. 브라우저의 핵심 기능은 사용자가 참조하고자 하는 웹페이지를 서버에 요청(Request)하고 ..
closure = function + environment : closure는 function이 하나 생길 때 마다 하나씩 생김 environment는 함수 자신을 둘러싼, 접근할 수 있는 모든 스코프를 뜻함 “A closure is the combination of a function and the lexical environment within which that function was declared.” 클로저는 함수와 그 함수가 선언됐을 때의 렉시컬 환경(Lexical environment)과의 조합이다. 위 정의에서 말하는 “함수”란 반환된 내부함수를 의미하고 “그 함수가 선언될 때의 렉시컬 환경(Lexical environment)”란 내부 함수가 선언됐을 때의 스코프를 의미한다. 즉, 클로저..
var는 선언부가 코드의 상단부로 hoisting된다 -> 변수의 선언만을 해당 스코프의 맨위로 올림 function도 hoisting의 대상이다 -> 선언이 아래에 있던 위에있던 해당 스코프에서는 사용가능 변수의 경우에는 선언과 초기화가 나뉘어져 있음 -> undefined될 수 있다. 하지만 함수의 경우에는 선언 밖에 없기때문에 hoisting에 의해 undefined가 아니라 선언된 내용이 불리어 질 수 있음 코드의 어떤 식별자가 실제 어떤 값을 가리키는지 결정하는 것을 binding이라고 함 자바스크립트에서 binding은 lexical scope를 통해 이루어짐 lexical scope란 간단히 말하면 안쪽에서 바깥쪽 변수에 접근할 수 있음 : 바깥쪽에서는 안쪽을 볼 수 없음 ex) var x ..