웹 프론트엔드 JS 튜토리얼 JavaScript_Basic 지식에서 문자열 연결 성능에 대해 알아야 할 몇 가지 문제

JavaScript_Basic 지식에서 문자열 연결 성능에 대해 알아야 할 몇 가지 문제

May 16, 2016 pm 05:34 PM
javascript

자바스크립트의 핵심은 ECMAScript입니다. 다른 언어와 마찬가지로 ECMAScript 문자열은 불변입니다. 즉, 해당 값을 변경할 수 없습니다.

다음 코드를 고려하세요.

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

var str = "hello ";
str = "world"; 실제로 이 코드가 이면에서 수행하는 단계는 다음과 같습니다.

1. 생성 "hello" 문자열을 저장하는 문자입니다.
2. "world"를 저장할 문자열을 만듭니다.
3. 연결 결과를 저장할 문자열을 만듭니다.
4. str의 현재 내용을 결과에 복사합니다.
5. 결과에 "world"를 복사합니다.
6. 결과를 가리키도록 str을 업데이트합니다.

문자열 연결이 완료될 때마다 2~6단계가 수행되므로 이 작업은 매우 리소스 집약적입니다. 이 프로세스를 수백, 수천 번 반복하면 성능 문제가 발생할 수 있습니다. 해결 방법은 Array 객체를 사용하여 문자열을 저장한 다음 Join() 메서드(매개 변수는 빈 문자열)를 사용하여 최종 문자열을 만드는 것입니다. 이전 코드를 다음 코드로 바꾸는 것을 상상해 보세요.

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

var arr = new Array();
arr[0] = "hello";
arr[1] = "world";
var str = arr.join("");

이렇게 하면 배열에 몇 개의 문자열이 추가되어도 문제가 되지 않습니다. 왜냐하면 Join() 메서드가 호출될 때만 조인 작업이 발생하기 때문입니다. 이때 수행할 단계는 다음과 같습니다.

1. 결과를 저장할 문자열을 생성합니다
2. 각 문자열을 결과의 적절한 위치에 복사합니다
이 해결 방법도 좋지만 더 좋은 방법이 있습니다. 문제는 이 코드가 의도한 바를 정확하게 반영하지 않는다는 것입니다. 이해하기 쉽도록 StringBuffer 클래스로 기능을 래핑할 수 있습니다.

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

function StringBuffer() {
this._strings_ = new Array();
}

StringBuffer.prototype.append = function(str) {
this._strings_.push(str);
};

StringBuffer.prototype.toString = function() {
return this._strings_.join("");
};


여기서 가장 먼저 주목해야 할 것은 코드는 문자열입니다. 속성은 비공개 속성을 의미합니다. 여기에는 두 가지 메서드, 즉 add() 및 toString() 메서드만 있습니다. Append() 메소드에는 문자열 배열에 매개변수를 추가하는 매개변수가 있습니다. toString() 메소드는 배열의 Join 메소드를 호출하고 실제 연결된 문자열을 반환합니다. StringBuffer 객체를 사용하여 문자열 집합을 연결하려면 다음 코드를 사용할 수 있습니다.
코드 복사 코드는 다음과 같습니다.

var buffer = new StringBuffer();
buffer.append("hello ");
buffer.append("world");
var result = buffer.toString ();

위 구현을 바탕으로 실행 시간을 비교해 보겠습니다. 즉, " "를 사용하여 문자열과 캡슐화된 도구를 하나씩 연결합니다. 다음 코드를 사용하여 StringBuffer 개체 및 기존 문자열 연결 방법의 성능을 테스트할 수 있습니다.
코드 복사 코드는 다음과 같습니다.

var d1 = new Date();
var str = "";
for (var i=0; i < 10000; i ) {
str = "text";
}
var d2 = new Date();

console.log("더하기 연결: "
(d2.getTime() - d1.getTime()) " 밀리초");

var buffer = new StringBuffer();
d1 = new Date();
for (var i=0; i < 10000; i ) {
buffer.append("text") ;
}
var result = buffer.toString();
d2 = new Date();

console.log("StringBuffer와의 연결: "
(d2.getTime() - d1.getTime()) " 밀리초");


이 코드는 문자열 연결에 대해 두 가지 테스트를 수행합니다. 첫 번째는 더하기 기호를 사용하고 두 번째는 StringBuffer 클래스를 사용합니다. 각 작업은 10,000개의 문자열을 연결합니다. 날짜 값 d1 및 d2는 작업을 완료하는 데 걸리는 시간을 결정하는 데 사용됩니다. 매개변수 없이 Date 객체를 생성하면 현재 날짜와 시간이 객체에 할당된다는 점에 유의하세요. 조인 작업에 걸린 시간을 계산하려면 getTime() 메서드의 반환 값을 사용하여 날짜의 밀리초 표현을 뺍니다. 이는 JavaScript 성능을 측정하는 일반적인 방법입니다. 이 테스트의 결과는 StringBuffer 클래스 사용과 더하기 기호 사용의 효율성을 비교하는 데 도움이 될 수 있습니다.

위 예시의 결과는 다음과 같습니다.

그러면 어떤 사람들은 JavaScript의 String 개체가 concat() 메서드도 캡슐화한다고 말할 수 있습니다. 또한 아래 concat() 메서드를 사용하여 콘솔에 다음 코드를 입력합니다.

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

var d1 = new Date();
var str = "";
for (var i=0; i < 10000; i ) {
str.concat("text");
}
var d2 = new Date();

console.log("더하기 연결: "
(d2.getTime() - d1.getTime()) " milliseconds");


완료된 것을 볼 수 있습니다. 10000회 문자를 연결하는 데 걸리는 시간은 다음과 같습니다.

일정 개수의 문자열 연결이 있을 경우 Java와 유사한 StringBuffer 개체(함수)를 Javascript에 캡슐화하여 작업을 수행하면 성능을 향상시킬 수 있다는 결론을 내릴 수 있습니다.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에서 int형을 문자열로 변환하는 방법에 대한 자세한 설명 PHP에서 int형을 문자열로 변환하는 방법에 대한 자세한 설명 Mar 26, 2024 am 11:45 AM

PHP에서 int 유형을 문자열로 변환하는 방법에 대한 자세한 설명 PHP 개발에서 int 유형을 문자열 유형으로 변환해야 하는 경우가 종종 있습니다. 이 변환은 다양한 방법으로 수행할 수 있습니다. 이 기사에서는 독자의 이해를 돕기 위해 특정 코드 예제와 함께 몇 가지 일반적인 방법을 자세히 소개합니다. 1. PHP 내장 함수 strval()을 사용하세요. PHP는 다양한 유형의 변수를 문자열 유형으로 변환할 수 있는 내장 함수 strval()을 제공합니다. int형을 string형으로 변환해야 할 때,

Golang 문자열이 지정된 문자로 끝나는지 확인하는 방법 Golang 문자열이 지정된 문자로 끝나는지 확인하는 방법 Mar 12, 2024 pm 04:48 PM

제목: Golang에서 문자열이 특정 문자로 끝나는지 확인하는 방법 Go 언어에서는 문자열을 처리할 때 문자열이 특정 문자로 끝나는지 확인해야 하는 경우가 있습니다. 이 기사에서는 Go 언어를 사용하여 이 기능을 구현하는 방법을 소개하고 참조용 코드 예제를 제공합니다. 먼저 Golang에서 문자열이 지정된 문자로 끝나는지 확인하는 방법을 살펴보겠습니다. Golang의 문자열에 포함된 문자는 인덱싱을 통해 얻을 수 있으며, 문자열의 길이는 다음과 같습니다.

Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Mar 12, 2024 pm 09:42 PM

Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Golang으로 프로그래밍할 때 문자열이 특정 문자로 시작하는지 확인해야 하는 상황에 자주 직면하게 됩니다. 이 요구 사항을 충족하기 위해 Golang의 문자열 패키지에서 제공하는 기능을 사용할 수 있습니다. 다음에는 Golang을 사용하여 문자열이 특정 문자로 시작하는지 확인하는 방법을 구체적인 코드 예제와 함께 자세히 소개하겠습니다. Golang에서는 strings 패키지의 HasPrefix를 사용할 수 있습니다.

python_python 반복 문자열 튜토리얼에서 문자열을 반복하는 방법 python_python 반복 문자열 튜토리얼에서 문자열을 반복하는 방법 Apr 02, 2024 pm 03:58 PM

1. 먼저 pycharm을 열고 pycharm 홈페이지로 들어갑니다. 2. 그런 다음 새 Python 스크립트를 생성하고 마우스 오른쪽 버튼을 클릭하고 새로 만들기를 클릭한 후 Pythonfile을 클릭합니다. 3. 문자열(코드: s="-")을 입력합니다. 4. 그런 다음 문자열의 기호를 20번 반복해야 합니다(코드: s1=s*20). 5. 인쇄 출력 코드(코드: print(s1))를 입력합니다. 6. 마지막으로 스크립트를 실행하면 하단에 반환 값이 표시됩니다. - 20번 반복됩니다.

PHP에서 16진수를 문자열로 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법 PHP에서 16진수를 문자열로 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법 Mar 04, 2024 am 09:36 AM

PHP에서 16진수 문자열을 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법 PHP 프로그래밍에서 때때로 16진수 문자열을 일반 중국어 문자로 변환해야 하는 상황에 직면합니다. 그러나 이러한 변환 과정에서 때때로 중국어 문자가 깨져 나오는 문제에 직면하게 됩니다. 이 기사에서는 PHP에서 16진수를 문자열로 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법과 구체적인 코드 예제를 제공합니다. 16진수 변환을 위해서는 hex2bin() 함수를 사용하세요. PHP에 내장된 hex2bin() 함수는 1을 변환할 수 있습니다.

PHP 문자열 일치 팁: 모호한 포함 표현식을 피하세요 PHP 문자열 일치 팁: 모호한 포함 표현식을 피하세요 Feb 29, 2024 am 08:06 AM

PHP 문자열 일치 팁: 모호한 포함 표현식 방지 PHP 개발에서 문자열 일치는 일반적으로 특정 텍스트 내용을 찾거나 입력 형식을 확인하는 데 사용되는 일반적인 작업입니다. 그러나 일치 정확도를 보장하기 위해 모호한 포함 표현식을 사용하지 말아야 할 경우도 있습니다. 이 기사에서는 PHP에서 문자열 일치를 수행할 때 모호한 포함 표현식을 방지하는 몇 가지 기술을 소개하고 구체적인 코드 예제를 제공합니다. 정확한 일치를 위해 preg_match() 함수를 사용하십시오. PHP에서는 preg_mat를 사용할 수 있습니다.

PHP 문자열 조작: 공백을 효과적으로 제거하는 실용적인 방법 PHP 문자열 조작: 공백을 효과적으로 제거하는 실용적인 방법 Mar 24, 2024 am 11:45 AM

PHP 문자열 작업: 공백을 효과적으로 제거하는 실용적인 방법 PHP 개발 시 문자열에서 공백을 제거해야 하는 상황에 자주 직면하게 됩니다. 공백을 제거하면 문자열이 더 깔끔해지고 후속 데이터 처리 및 표시가 쉬워집니다. 이 기사에서는 공백을 제거하는 몇 가지 효과적이고 실용적인 방법을 소개하고 구체적인 코드 예제를 첨부합니다. 방법 1: PHP 내장 함수인 Trim()을 사용합니다. PHP 내장 함수인 Trim()을 사용하면 문자열 양쪽 끝의 공백(공백, 탭, 개행 등 포함)을 제거할 수 있어 매우 편리하고 쉽습니다. 사용.

문자열의 마지막 두 문자를 삭제하는 PHP 기술 문자열의 마지막 두 문자를 삭제하는 PHP 기술 Mar 23, 2024 pm 12:18 PM

웹 애플리케이션 개발에 널리 사용되는 스크립팅 언어로서 PHP는 매우 강력한 문자열 처리 기능을 가지고 있습니다. 일상적인 개발 과정에서 문자열, 특히 문자열의 마지막 두 문자를 삭제해야 하는 작업을 자주 접하게 됩니다. 이 기사에서는 문자열의 마지막 두 문자를 삭제하는 두 가지 PHP 기술을 소개하고 구체적인 코드 예제를 제공합니다. 팁 1: substr 함수 사용 PHP의 substr 함수는 문자열의 일부를 반환하는 데 사용됩니다. 문자열과 시작 위치를 지정하여 쉽게 문자를 제거할 수 있습니다.

See all articles