> 웹 프론트엔드 > JS 튜토리얼 > Node.js는 성능 문제를 고려하여 너무 많은 횟수로 루프를 최적화합니다.

Node.js는 성능 문제를 고려하여 너무 많은 횟수로 루프를 최적화합니다.

高洛峰
풀어 주다: 2017-02-04 13:18:53
원래의
1341명이 탐색했습니다.

1천만 개의 난수를 생성한다고 가정합니다. 일반적인 접근 방식은 다음과 같습니다.

var numbers = []; 
for (var i = 0; i < 10000000; i++) { 
  numbers.push(Math.random()); 
}
로그인 후 복사

그러나 IE에서 이 코드를 실행하면 사용자에게 이 스크립트를 중지할지 묻는 창이 나타납니다. 이런 일이 발생하면 가장 먼저 떠오르는 것은 루프 본문을 최적화하는 것입니다. 그러나 분명히 루프 본문은 매우 단순하며 최적화할 여지가 없습니다. 루프 본문이 지워지더라도 프롬프트는 여전히 존재합니다. 그래서 저는 결론을 내렸습니다. IE에서는 루프 수가 특정 값을 초과하면 스크립트를 중지하라는 메시지가 나타납니다.

원인은 찾았는데 어떻게 해결하나요? 나의 첫 번째 생각은 천만 개의 루프를 여러 개의 작은 루프로 나누는 것이었습니다. 예를 들어, 100번으로 나누고 매번 10만 개의 루프를 실행합니다.

for (var i = 0, j; i < 100; i++) { 
  for (j = 0; j < 100000; j++) { 
    ...... 
  } 
}
로그인 후 복사

IE는 우리가 생각하는 것만큼 멍청하지 않으며 총 루프 수가 여전히 천만이라는 것을 알고 있습니다. 따라서 이러한 10만 주기는 별도로 실행되어야 합니다. Javascript는 단일 스레드이지만 setTimeout 또는 setInterval을 통해 다중 스레드를 시뮬레이션할 수도 있습니다. 전체 코드는 다음과 같이 최적화됩니다.

var numbers = []; 
function begin() { 
  for (var i = 0; i < 100000; i++) { 
    numbers.push(Math.random()); 
  } 
  if (numbers.length < 10000000) { // 是否已完成 
    setTimeout(begin, 0); 
  } else { 
    alert("complete"); 
  } 
} 
begin();
로그인 후 복사

더 많은 js 최적화 루프가 너무 많이 발생하므로 성능 문제를 고려하여 관련 기사를 보려면 PHP 중국어 웹사이트에 주목하세요.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿