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 [펌] TAEYO.NET - JavaScript OOP 스트레칭 황제낙엽 2009.04.02 27
76 Rhino scopes and contexts 에 대한 문서 황제낙엽 2008.07.18 27
75 Fetch API (CORS 극복을 위한 노력) 황제낙엽 2021.12.05 26
74 유용한 자바스크립트 예제 몇가지 (Tree 및...) file 황제낙엽 2005.10.20 26
73 링크모음 황제낙엽 2011.03.25 25
72 YUI Logger(Yahoo) 를 동적으로 로드하는 북마크릿 황제낙엽 2010.10.03 25
71 생성자 체인과 상속 황제낙엽 2008.08.08 24
70 Date객체 - 날짜구하기 file 황제낙엽 2008.02.19 24
69 CORS(Cross-Origin Resource Sharing) - 2 황제낙엽 2017.03.07 24
68 연산자 this 황제낙엽 2014.12.30 23
67 URI 인코딩을 해야 하는 문자들 황제낙엽 2009.09.02 23
66 [펌] 아사페릴의 사생활 - __proto__ 와 construct 와 prototype 황제낙엽 2009.04.02 23
65 String xml 파싱 황제낙엽 2008.11.03 23
64 XML+JS 연동 다중셀렉트박스 (1) - <font color="brown">(MS Explorer 전용)</brown> 황제낙엽 2005.12.02 23
63 파이어폭스로 스크립트 디버깅하기 황제낙엽 2009.01.14 22
62 동적인 언어를 동적으로 호출하기 file 황제낙엽 2008.07.14 22
61 [펌] TAEYO.NET - JavaScript OOP 코어객체와 prototype를 사용한 객체확장 황제낙엽 2009.04.02 21
60 Object 와 Prototype 황제낙엽 2008.08.08 21
59 [펌]자바스크립트에서 객체 생성 방법 황제낙엽 2008.08.07 21
58 감추기, 보이기 화면 예제 황제낙엽 2008.04.14 21