데이터 베이스 MySQL 튜토리얼 stl中的map、set、multimap、multiset,兼谈OceanBase造轮子

stl中的map、set、multimap、multiset,兼谈OceanBase造轮子

Jun 07, 2016 pm 03:22 PM
map set stl

终于有机会有动力有能力看jjhou的《STL源码解析》了。采取快速翻阅模式,有望看完整本。 map和set的底层机制都是RB-Tree(红黑树),插入和查找都是O(lgN)的复杂度。map、set以前听说过,但从来不用,因为不了解,不知道背后是什么。通过读这本书了解到了其

终于有机会有动力有能力看jjhou的《STL源码解析》了。采取快速翻阅模式,有望看完整本。

map和set的底层机制都是RB-Tree(红黑树),插入和查找都是O(lgN)的复杂度。map、set以前听说过,但从来不用,因为不了解,不知道背后是什么。通过读这本书了解到了其背后的机制,也许在将来会用一用。

multimap和multiset没什么,只是对map和set的小修改而已。

除了这些,还有hash_map、hash_set,其底层机制不是RB-Tree,而是hash table。

了解到这些之后,map、set这些,都不神秘,都可控了。

目前还有一点需要再动手捉摸下:内存管理。STL的simple_allocator可定制行到底如何,得看看。

关于stl使用,最好的参考书莫过于cplusplus.com了

再扯一句OceanBase与STL。

OceanBase中几乎没有使用任何stl提供的功能,基本是在重复“发明轮子”,不过这种发明某种程度上我觉得看上去是合理的,比如:返回码、错误码的定制,这一点就具有很大的灵活性;内存使用方面可定制性也大很多;另外,也轻量很多;再另外,STL的接口也用得蛮头疼,一大段代码,全围着接口转了,也有办法不围着,多用用typedef就会看上去好很多。为什么OceanBase不用STL呢?我想,本质原因还是我们有一群很牛逼的工程师,有能力写出经得起考验的底层代码。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

springboot는 yml 파일의 목록, 배열, 지도 컬렉션 및 개체를 어떻게 읽나요? springboot는 yml 파일의 목록, 배열, 지도 컬렉션 및 개체를 어떻게 읽나요? May 11, 2023 am 10:46 AM

application.yml은 목록 컬렉션을 정의합니다. 첫 번째 방법은 @ConfigurationProperties 주석을 사용하여 목록 컬렉션 유형:code:status:-200-300-400-500의 모든 값을 얻는 것입니다. 여기서 주목해야 할 점은 목록 Collection을 정의하고 먼저 구성 클래스 Bean을 정의한 다음 @ConfigurationProperties 주석을 사용하여 목록 컬렉션 값을 얻는다는 것입니다. @Component는 엔티티 클래스를 Spring 관리 @ConfigurationPropertie에 넘겨줍니다.

MyBatis 동적 SQL 태그의 Set 태그 기능에 대한 자세한 설명 MyBatis 동적 SQL 태그의 Set 태그 기능에 대한 자세한 설명 Feb 26, 2024 pm 07:48 PM

MyBatis 동적 SQL 태그 해석: Set 태그 사용법에 대한 자세한 설명 MyBatis는 풍부한 동적 SQL 태그를 제공하고 데이터베이스 작업 명령문을 유연하게 구성할 수 있는 탁월한 지속성 계층 프레임워크입니다. 그 중 Set 태그는 업데이트 작업에서 매우 일반적으로 사용되는 UPDATE 문에서 SET 절을 생성하는 데 사용됩니다. 이 기사에서는 MyBatis에서 Set 태그의 사용법을 자세히 설명하고 특정 코드 예제를 통해 해당 기능을 보여줍니다. Set 태그란 무엇입니까? Set 태그는 MyBati에서 사용됩니다.

Java에서 만료 시간 맵을 설정하는 방법 Java에서 만료 시간 맵을 설정하는 방법 May 04, 2023 am 10:13 AM

1. 기술적 배경 실제 프로젝트 개발에서는 시스템의 가용성과 견고성을 향상시키기 위해 캐싱 미들웨어(예: redis, MemCache 등)를 자주 사용합니다. 하지만 프로젝트가 상대적으로 단순하다면 캐싱을 사용하기 위해 시스템의 복잡성을 높이기 위해 Redis와 같은 미들웨어를 특별히 도입할 필요가 없는 경우가 많습니다. 그렇다면 Java 자체에는 유용한 경량 캐싱 구성 요소가 있습니까? 물론 대답은 '그렇다'이며, 방법은 여러 가지가 있습니다. 일반적인 솔루션에는 ExpiringMap, LoadingCache 및 HashMap 기반 패키징이 포함됩니다. 2. 오래된 삭제 전략, 핫스팟 데이터 워밍업 등 캐시의 공통 기능을 구현하기 위한 기술적 효과 3. ExpiringMap3.

Java에서 객체를 맵으로 변환하는 방법 - BeanMap을 사용하여 Java에서 객체를 맵으로 변환하는 방법 - BeanMap을 사용하여 May 08, 2023 pm 03:49 PM

javabeans와 map을 변환하는 방법에는 여러 가지가 있습니다. 1. ObjectMapper를 통해 Bean을 json으로 변환한 다음 json을 map으로 변환합니다. 그러나 이 방법은 테스트 후에 10,000개의 Bean이 루프로 변환되었습니다. 12초 걸립니다! ! ! 2. Java Reflection을 통해 Bean 클래스의 속성과 값을 얻은 다음 이를 맵에 해당하는 키-값 쌍으로 변환하는 방법이 두 번째로 좋지만 조금 더 번거롭습니다. 3. 클래스의 net.sf.cglib.beans.BeanMap 메소드를 통해 이 메소드는 매우 효율적입니다. 두 번째 메소드와 차이점은 캐시를 사용하기 때문에 첫 번째 Bean을 생성할 때 초기화해야 한다는 것입니다. 시간.

C++ STL에서 사용자 정의 비교기를 구현하는 방법은 무엇입니까? C++ STL에서 사용자 정의 비교기를 구현하는 방법은 무엇입니까? Jun 05, 2024 am 11:50 AM

사용자 정의 비교기를 구현하려면 두 개의 매개변수를 허용하고 비교 결과를 나타내는 Operator()를 오버로드하는 클래스를 생성하면 됩니다. 예를 들어, StringLengthComparator 클래스는 길이를 비교하여 문자열을 정렬합니다. 클래스를 만들고 연산자()를 오버로드하여 비교 결과를 나타내는 부울 값을 반환합니다. 컨테이너 알고리즘 정렬을 위해 사용자 정의 비교기를 사용합니다. 사용자 정의 비교기를 사용하면 사용자 정의 비교 기준을 사용해야 하는 경우에도 사용자 정의 기준에 따라 데이터를 정렬하거나 비교할 수 있습니다.

Go 언어 맵의 성능 최적화 Go 언어 맵의 성능 최적화 Mar 23, 2024 pm 12:06 PM

Go 언어 맵의 성능 최적화 Go 언어에서 맵은 키-값 쌍 모음을 저장하는 데 사용되는 매우 일반적으로 사용되는 데이터 구조입니다. 그러나 대량의 데이터를 처리하는 경우 지도 성능이 저하될 수 있습니다. 지도의 성능을 향상시키기 위해 몇 가지 최적화 조치를 취하여 지도 작업의 시간 복잡성을 줄여 프로그램의 실행 효율성을 향상시킬 수 있습니다. 1. 맵 용량을 사전 할당합니다. 맵 생성 시 용량을 사전 할당하여 맵 확장 횟수를 줄이고 프로그램 성능을 향상시킬 수 있습니다. 일반적으로 우리는

Nginx 서버에서 맵 모듈을 구성하고 사용하는 방법 Nginx 서버에서 맵 모듈을 구성하고 사용하는 방법 May 21, 2023 pm 05:14 PM

맵 명령은 ngx_http_map_module 모듈에서 제공됩니다. 기본적으로 nginx는 인위적으로 --without-http_map_module을 사용하지 않는 한 이 모듈을 로드합니다. ngx_http_map_module 모듈은 값이 다른 변수의 값과 연관된 변수를 생성할 수 있습니다. 여러 값을 여러 다른 값으로 분류하거나 동시에 매핑하고 변수에 저장하는 것을 허용합니다. 맵 지시어는 변수를 생성하는 데 사용되지만 변수가 허용되는 경우에만 뷰 매핑 작업을 수행합니다. 변수를 참조하지 않는 요청을 처리하는 경우 이 모듈에는 성능 단점이 없습니다. 1.ngx_http_map_module 모듈 명령어 설명 맵 구문

C++ STL 컨테이너의 크기를 얻는 방법은 무엇입니까? C++ STL 컨테이너의 크기를 얻는 방법은 무엇입니까? Jun 05, 2024 pm 06:20 PM

컨테이너의 size() 멤버 함수를 사용하여 컨테이너의 요소 수를 가져올 수 있습니다. 예를 들어, 벡터 컨테이너의 size() 함수는 요소 수를 반환하고, 목록 컨테이너의 size() 함수는 요소 수를 반환하고, 문자열 컨테이너의 length() 함수는 문자 수를 반환하며, deque 컨테이너의 용량() 함수는 할당된 메모리 블록 수를 반환합니다.

See all articles