> 백엔드 개발 > C++ > Visual Studio 2015에서 std::list::sort()에 대해 상향식 병합 정렬에서 하향식 병합 정렬로 전환한 이유는 무엇인가요?

Visual Studio 2015에서 std::list::sort()에 대해 상향식 병합 정렬에서 하향식 병합 정렬로 전환한 이유는 무엇인가요?

Linda Hamilton
풀어 주다: 2024-10-31 03:28:30
원래의
718명이 탐색했습니다.

Why did Visual Studio 2015 switch from bottom-up to top-down merge sort for std::list::sort()?

std::list::sort() - 갑자기 하향식 전략으로 전환한 이유는 무엇입니까?

Visual Studio 2015에서는 std::list::sort() 구현은 전통적인 상향식 병합 정렬에서 하향식 병합 정렬로 크게 변경되었습니다. 이러한 변화로 인해 각 재귀 수준에서 목록의 중간점을 찾아야 하므로 명백한 비효율성이 발생했습니다.

변경 이유:

그러나 제공된 업데이트에서 Microsoft는 반복기 사용에 대한 초기 변경을 동기를 부여한 메모리 할당 없음 및 예외 안전 수정 사항을 유지하기 위해 최적화를 수행했습니다. 특히 재귀 구현은 다음과 같습니다.

  • 목록을 스캔하는 대신 각 재귀 수준에서 목록을 2로 나누는 효율적인 병합 정렬을 사용합니다.
  • 대신 포인터를 사용하여 되돌립니다. 잠재적으로 성능을 향상시킵니다.
  • 한 번에 여러 노드의 병합을 개선하기 위해 스플라이스 논리를 구현합니다.

상향식 병합 정렬과 비교:

최적화에도 불구하고 하향식 접근 방식은 캐시 누락 증가로 인해 크고 분산된 연결 목록을 처리할 때 여전히 상향식 병합 정렬보다 느릴 가능성이 있습니다.

대체 구현:

목록 배열 대신 반복자를 활용하면서 상향식 병합 정렬 접근 방식을 유지하는 대체 구현이 제공됩니다. 이 접근 방식은 재귀 중에 항상 목록의 중간점을 찾아야 하는 성능 저하를 피하는 것을 목표로 합니다.

결론:

Visual에서 하향식 병합 정렬로 전환 Studio 2015는 즉흥적으로 만들어진 것이 아닙니다. Microsoft는 예외 안전성의 이점을 유지하고 메모리 할당을 줄이는 동시에 잠재적인 비효율성을 해결하기 위해 최적화를 구현했습니다. 그러나 규모가 크고 인구가 적은 연결 목록의 경우 상향식 병합 정렬 접근 방식이 여전히 더 나은 성능을 제공할 수 있습니다.

위 내용은 Visual Studio 2015에서 std::list::sort()에 대해 상향식 병합 정렬에서 하향식 병합 정렬로 전환한 이유는 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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