js 정규 표현식_javascript 기술의 성능을 확인하기 위해 프로토타입 기능 다듬기
일반적으로 일반적인 작성 방법은 다음과 같습니다.
[Ctrl A 모두 선택 참고: 외부 J를 도입해야 하는 경우 실행하려면 새로 고쳐야 합니다.
빅데이터가 발생하는 경우 문자열의 길이를 변경하면 매우 리소스 집약적이라는 것을 알 수 있습니다. 그다지 효율적이지 않으며 때로는 참을 수 없을 때도 있습니다. 외부 J를 도입해야 하는 경우 실행하려면 새로 고쳐야 합니다.
]
이전에 마스터 정규 표현식에서 언급한 것을 본 기억이 나는 이유를 설명합니다. NFA와 DFA의 엔진에는 차이가 있습니다. js/perl/php/java/.net은 모두 NFA 엔진입니다.
DFA와 NFA의 메커니즘 차이는 다음과 같이 5가지 영향을 미칩니다.
1. DFA는 텍스트 문자열의 각 문자를 한 번만 스캔하면 되므로 속도는 더 빠르지만 NFA가 문자를 계속해서 처리해야 합니다. 음성 문자는 느리지만 기능이 풍부하여 널리 사용됩니다. Perl, Ruby, Python의 re 모듈, Java 및 .NET의 regex 라이브러리 등이 모두 NFA입니다.
2. NFA만 게으른 및 역참조와 같은 기능을 지원합니다.
3. NFA는 가장 왼쪽의 하위 정규식이 먼저 일치하므로 가끔 가장 일치하는 결과가 누락됩니다. 가장 긴 왼쪽 하위 정규 표현식이 먼저 일치합니다."
4. NFA는 기본적으로 탐욕 수량자를 사용합니다. 즉, /.*/ 및 /w /와 같이 "n"번 반복되는 패턴의 경우 탐욕 방식으로 수행되며 최대한 많은 문자와 일치합니다. 더 이상 포기할 수 없을 때까지) NFA는 수량자를 먼저 일치시킵니다.
5. NFA는 재귀 호출의 함정에 빠져 성능이 극도로 저하될 수 있습니다.
역추적
NFA는 너무 많이 먹었음을 발견하면 하나씩 뱉어내며 일치하는 항목을 찾는 과정을 역추적이라고 합니다. 이러한 프로세스의 존재로 인해 NFA 매칭 과정 중, 특히 불합리한 정규식 매칭을 작성할 경우 텍스트를 반복적으로 스캔하게 되어 효율성 손실이 상당합니다. 이 원리를 이해하는 것은 효율적인 정규식을 작성하는 데 매우 도움이 됩니다.
이유를 찾아 분석해보세요
위의 트림 프로토타입 방법을 설명할 때. 테스트 후 결과가 올바른지 여부에 관계없이 JS NFA 엔진의 에코 수를 해결할 수 있는 방법은 여러 가지가 있습니다
String.prototype.trim = function() {
이것을 반환합니다. replacement(/^[st] | [st ]$/g, '');
}
b. 문자열 끝 일치를 제거합니다. 즉, 다음과 같이 변경합니다. 코드는 다음과 같습니다.
String .prototype.trim = function ( ) {
return this.replace(/^[st ] /g, '')
}
c. 즉, 다음과 같이 변경합니다. 코드는 다음과 같습니다.
String .prototype.trim = function ( ) {
return this.replace(/^[st ] |[st ] $/mg, '');
从以上三种改法结合文中开头的NFA资料,我们可以大概的知道trim性能出现问题的原因
量词限定将优先匹配。
量词限定在结尾可能会使JS的正则引擎不停的回朔,出现递归的一个陷阱,这个递归的深度太深。如果字符串更大一点应该会出现栈溢出了。
多行既然能够匹配,而且性能消耗不大。性能上没有任何问题,从一个写这个正则程序的人角度上去看,多行明显比单行要替换的空串多得多。所以第二点的结论应该是对的
改良
首先确定匹配字符串的开始正则是没有任何效率问题的。而匹配结束的时候会出现性能问题,那可以采用正则与传统相结合来改善这个trim性能问题。
例如:

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제









Ollama는 Llama2, Mistral, Gemma와 같은 오픈 소스 모델을 로컬에서 쉽게 실행할 수 있는 매우 실용적인 도구입니다. 이번 글에서는 Ollama를 사용하여 텍스트를 벡터화하는 방법을 소개하겠습니다. Ollama를 로컬에 설치하지 않은 경우 이 문서를 읽을 수 있습니다. 이 기사에서는 nomic-embed-text[2] 모델을 사용합니다. 짧은 컨텍스트 및 긴 컨텍스트 작업에서 OpenAI text-embedding-ada-002 및 text-embedding-3-small보다 성능이 뛰어난 텍스트 인코더입니다. o를 성공적으로 설치한 후 nomic-embed-text 서비스를 시작하십시오.

정규식을 사용하여 Golang에서 이메일 주소를 확인하려면 다음 단계를 따르세요. regexp.MustCompile을 사용하여 유효한 이메일 주소 형식과 일치하는 정규식 패턴을 만듭니다. MatchString 함수를 사용하여 문자열이 패턴과 일치하는지 확인합니다. 이 패턴은 다음을 포함하여 대부분의 유효한 이메일 주소 형식을 다룹니다. 로컬 사용자 이름에는 문자, 숫자 및 특수 문자가 포함될 수 있습니다: !.#$%&'*+/=?^_{|}~-`도메인 이름에는 최소한 다음이 포함되어야 합니다. 문자 1개 뒤에 문자, 숫자 또는 하이픈이 옵니다. 최상위 도메인(TLD)의 길이는 63자를 초과할 수 없습니다.

다양한 Java 프레임워크의 성능 비교: REST API 요청 처리: Vert.x가 최고이며 요청 속도는 SpringBoot의 2배, Dropwizard의 3배입니다. 데이터베이스 쿼리: SpringBoot의 HibernateORM은 Vert.x 및 Dropwizard의 ORM보다 우수합니다. 캐싱 작업: Vert.x의 Hazelcast 클라이언트는 SpringBoot 및 Dropwizard의 캐싱 메커니즘보다 우수합니다. 적합한 프레임워크: 애플리케이션 요구 사항에 따라 선택하세요. Vert.x는 고성능 웹 서비스에 적합하고, SpringBoot는 데이터 집약적 애플리케이션에 적합하며, Dropwizard는 마이크로서비스 아키텍처에 적합합니다.

PHP 배열 키 값 뒤집기 방법의 성능 비교는 array_flip() 함수가 대규모 배열(100만 개 이상의 요소)에서 for 루프보다 더 나은 성능을 발휘하고 시간이 덜 걸리는 것을 보여줍니다. 키 값을 수동으로 뒤집는 for 루프 방식은 상대적으로 시간이 오래 걸립니다.

Go에서는 정규식을 사용하여 타임스탬프를 일치시킬 수 있습니다. ISO8601 타임스탬프를 일치시키는 데 사용되는 것과 같은 정규식 문자열을 컴파일합니다. ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ . regexp.MatchString 함수를 사용하여 문자열이 정규식과 일치하는지 확인합니다.

C++ 다중 스레드 성능을 최적화하기 위한 효과적인 기술에는 리소스 경합을 피하기 위해 스레드 수를 제한하는 것이 포함됩니다. 경합을 줄이려면 가벼운 뮤텍스 잠금을 사용하세요. 잠금 범위를 최적화하고 대기 시간을 최소화합니다. 동시성을 향상하려면 잠금 없는 데이터 구조를 사용하세요. 바쁜 대기를 피하고 이벤트를 통해 스레드에 리소스 가용성을 알립니다.

정적 함수 성능 고려 사항은 다음과 같습니다. 코드 크기: 정적 함수는 멤버 변수를 포함하지 않기 때문에 일반적으로 더 작습니다. 메모리 점유: 특정 객체에 속하지 않으며 객체 메모리를 점유하지 않습니다. 호출 오버헤드: 낮음, 객체 포인터나 참조를 통해 호출할 필요가 없습니다. 다중 스레드로부터 안전함: 클래스 인스턴스에 대한 종속성이 없기 때문에 일반적으로 스레드로부터 안전합니다.

Go에서 정규식을 사용하여 비밀번호를 확인하는 방법은 다음과 같습니다. 최소 비밀번호 요구 사항(소문자, 대문자, 숫자, 특수 문자를 포함하여 8자 이상)을 충족하는 정규식 패턴을 정의합니다. regexp 패키지의 MustCompile 함수를 사용하여 정규식 패턴을 컴파일합니다. MatchString 메서드를 사용하여 입력 문자열이 정규식 패턴과 일치하는지 테스트합니다.
