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는 동일하다.


번호 제목 글쓴이 날짜 조회 수
77 [펌] 아사페릴의 사생활 - __proto__ 와 construct 와 prototype 황제낙엽 2009.04.02 23
76 [펌] 아사페릴의 사생활 - prototype과 __proto__ 와 constructor 황제낙엽 2009.04.02 41
75 [펌] 아사페릴의 사생활 - __proto__ 와 prototype에 대해.. 황제낙엽 2009.04.02 15
74 [펌] 아사페릴의 사생활 - Javascript의 클래스에 관한 이야기 황제낙엽 2009.04.02 17
73 [펌] 아사페릴의 사생활 - Javascript의 constructor 와 prototype 황제낙엽 2009.04.02 156
» [펌] prototype (2) 황제낙엽 2009.04.02 9
71 [펌] prototype (1) 황제낙엽 2009.04.02 12
70 unshift() Method 황제낙엽 2009.03.02 287
69 javascript replaceall의 방법에 따른 처리 속도 비교 황제낙엽 2009.02.11 97
68 파이어폭스로 스크립트 디버깅하기 황제낙엽 2009.01.14 22
67 숫자 여부와 자리수를 체크 하는 예제 황제낙엽 2009.01.12 5265
66 익스플로러용 스크립트 디버거 (Script Debugger for Windows NT 4.0 and Later) 황제낙엽 2008.12.11 176
65 소숫점을 포함한 반올림 황제낙엽 2008.12.11 62
64 int * float 연산 오류 file 황제낙엽 2008.12.11 95
63 JavaScript Form Validation file 황제낙엽 2008.11.24 186
62 정규식 정리 황제낙엽 2008.11.24 252
61 setTimeout() / setInterval() 메소드 황제낙엽 2008.11.05 111
60 [key:value] 형태로 object를 저장할 수 있는 Static영역의 해쉬맵 클래스 (Map) 황제낙엽 2008.11.04 46
59 String xml 파싱 황제낙엽 2008.11.03 23
58 innerHTML 황제낙엽 2008.11.03 93