Prototype [펌] prototype (2)

황제낙엽 2009.04.02 20:13 조회 수 : 9 추천:105

sitelink1  
sitelink2  
sitelink3  
sitelink4 http://1 
extra_vars4 ko 
extra_vars5 http://jaures.egloos.com/2263963 
extra_vars6 sitelink1 
prototype은 모든 instance가 공유하는 property라고 생각하면 된다. (다른 언어에서는 마치 class 객체와 같은 형태)

하지만 다른 언어와는 달리 prototype은 runtime 중에 얻어 오거나 또는 변경이 가능하며, 새로 추가하거나 삭제도 가능하다. 모두 runtime 중에 말이다. 

모든 변경에 대한 내역은 해당 작업이 이루어지는 순간 즉시 반영이 되게 되기 때문에, 이미 instance가 생성된 객체에서도 변경한 내용을 바로 사용할 수 있다.

이것이 가능한 일은 Javascript는 컴파일 되지 않고 요청이 있을때마다 동적으로 요청된 property를 찾기 때문인데 다음의 예를 살펴보자.

A 객체가 B의 객체를 상속받는 과정을 생각해 보자. (B.prototype -> A.prototype)
A 객체의 instance가 생성된 a (var a = new A())가 있다고 할때, a의 property를 요청하면 다음과 같은 과정을 거치게 된다.

1. Javascript는 a 객체에서 요청된 property가 해당 객체에 존재 하는지를 확인한다. 찾지 못했다면 다음 과정으로 이동한다.

2. Javascript는 a의 prototype 객체인 "A.prototype"에서 해당 property를 찾는다. 여기서도 찾지 못했다면 다시 다음 과정으로 이동한다.

3. Javascript는 마지막으로 A가 상속받은 "B.prototype"에서 요청된 property를 찾고 해당 property를 return 하게 된다.

이와 같이 각 객체의 prototype에 대한 검색은 요청된 property를 찾기위해 root property까지 계속된다. 이렇게 각 객체마다 연결된 형태를 "prototype chain이라고 한다.

* 참고 : 현재 object에서 property를 찾는 속도는, prototype chain을 통해 검색하는 것보다 약 25%의 빠르다고 한다. 즉, prototype을 통해 상속받은 property가 아닌 현재 object에 존재하는 property를 얻어오는 것이 더 빠르다는 의미이다. - High Performance Ajax Application, p17
    
    
다음과 같은 function A가 있다고 하자.

function A() { ... }

new A() 가 실행되면, 실제로는 2개의 객체가 생성된다. constructor 객체 "A"와 constructor와 연관된 익명의 prototype 객체 "A.prototype".

객체의 instace를 다음과 같이 생성하면,

var a = new A();

Javascript는 instance 객체인 "a"와 constructor의 prototype인 "A.prototype"간에 permanent link를 생성하게 된다. 이건 외부에 노출되지 않는 "private prototype" 이다. 다음의 코드를 통해 이를 확인해 볼수 있다.

Array의 push() 를 재작성 한다고 할때에 다음과 같이 작성한다.

1) Array.prototype.push = function () { ... };

또는 

2) var a = new Array();
    a.constructor.prototype.push = function () { ... }

a.contruct.protype 즉, private prototype을 이용해 상위의 Array.prototype에 접근하고 있다. 1과 2는 동일하다.


번호 제목 글쓴이 날짜 조회 수
30 상속과 Super 로의 접근 황제낙엽 2012.09.18 64
29 inherits() 를 이용한 상속 황제낙엽 2012.07.18 129
28 Defining classes and inheritance (클래스 정의와 상속) 황제낙엽 2011.03.24 392
27 JavaScript Closures for Dummies 황제낙엽 2009.04.08 227
26 체인 생성자(생성자 체인), 프로토타입 체인 그리고 생성자 재지정 황제낙엽 2009.08.12 55
25 [펌] TAEYO.NET - Js OOP - 나만의 프레임워크 만들기 황제낙엽 2009.04.02 18
24 [펌] TAEYO.NET - Js OOP - 사용자 정의 객체. 그리고 상속과 재사용 황제낙엽 2009.04.02 16
23 [펌] TAEYO.NET - JavaScript OOP 코어객체와 prototype를 사용한 객체확장 황제낙엽 2009.04.02 21
22 [펌] 아사페릴의 사생활 - 싱글톤 패턴을 지향한 Javascript Module Pattern 황제낙엽 2009.04.02 90
21 [펌] 아사페릴의 사생활 - Code Conventions for the JavaScript Programming Language 황제낙엽 2009.04.02 194
20 [펌] 아사페릴의 사생활 - __proto__ 와 construct 와 prototype 황제낙엽 2009.04.02 23
19 [펌] 아사페릴의 사생활 - prototype과 __proto__ 와 constructor 황제낙엽 2009.04.02 41
18 [펌] 아사페릴의 사생활 - __proto__ 와 prototype에 대해.. 황제낙엽 2009.04.02 15
17 [펌] 아사페릴의 사생활 - Javascript의 클래스에 관한 이야기 황제낙엽 2009.04.02 17
16 [펌] 아사페릴의 사생활 - Javascript의 constructor 와 prototype 황제낙엽 2009.04.02 156
» [펌] prototype (2) 황제낙엽 2009.04.02 9
14 [펌] prototype (1) 황제낙엽 2009.04.02 12
13 [key:value] 형태로 object를 저장할 수 있는 Static영역의 해쉬맵 클래스 (Map) 황제낙엽 2008.11.04 46
12 함수와 인자값 (arguments) 황제낙엽 2008.08.12 15
11 중첩 함수, 함수 클로저 황제낙엽 2008.08.12 820