>웹 프론트엔드 >JS 튜토리얼 >Array의 push 및 unshift 방식의 성능 비교 분석_javascript 기술

Array의 push 및 unshift 방식의 성능 비교 분석_javascript 기술

WBOY
WBOY원래의
2016-05-16 18:09:491632검색

원리를 보면 언시프트의 효율성이 낮다는 것을 알 수 있습니다. 그 이유는 요소를 추가할 때마다 기존 요소를 한 위치 아래로 이동시키기 때문입니다. 하지만 효율성 차이는 얼마나 큽니까? 아래에서 테스트해 보겠습니다.
테스트 환경의 주요 하드웨어: CPU T7100(1.8G) 메모리 4G DDR2 667; 주요 소프트웨어: 운영 체제는 Windows 7이고 브라우저는 Firefox 3.6.9입니다. 테스트 코드:

코드 복사 코드는 다음과 같습니다.

var arr = [ ], s = new Date;// 푸시 성능 테스트
for (var i = 0; i < 50000; i ) {
 arr.push(i)
}
콘솔. log( new Date - s);
s = new Date; arr = [ ]
// unshift 성능 테스트
for (var i = 0; i < 50000; i )
arr.unshift(i);
}
console.log( new Date - s);


이 코드는 한 번 실행된 후 각각 push 및 unshift 작업을 수행합니다. , 결과는 다음과 같습니다.
12
1152
unshift가 push보다 거의 100배 느린 것을 볼 수 있습니다! 따라서 특히 대규모 배열의 경우 unshift를 주의해서 사용해야 합니다. 그렇다면 unshift 효과를 달성해야 한다면 다른 방법이 있을까요? 대답은 '예'입니다.
Array에는 배열을 뒤집을 수 있는 reverse라는 메서드가 있습니다. 먼저 push를 사용하여 배열에 넣을 요소를 추가한 다음 다시 역순으로 수행하여 이동 해제 효과를 얻습니다. 예:


for (var i = 0 ; i < 50000; i ) {
 arr.push(i);
}
arr.reverse()


테스트해볼까요? 다시 실행합니다:


var arr = [ ], s = new Date; for (var i = 0; i < 50000; i ) {
 arr.push(i)
}
arr.reverse(); .log( new Date - s) ;


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