c++의 malloc 바 텀 구현 코드
malloc 밑바닥 실현
우선 malloc 라 는 함 수 를 말씀 드 리 겠 습 니 다.
void* malloc(size_t size);
malloc 는 c 의 함수 입 니 다.호출 할 때 표시 해 야 할 지정 한 할당 공간의 크기 입 니 다.할당 에 성공 하면void *
의 지침 을 되 돌려 줍 니 다.스스로 강제 변환 을 해 야 합 니 다.안전 하지 않 습 니 다.NULL 로 돌아 가 는 데 실 패 했 습 니 다.상관 함수
int brk(const void *addr)
함 수 는 힙 의 상계 brk 를 확장 하기 위 한 것 이다.0 성공.-1 실패.
void* sbrk(intprt_t incr)
메모리 크기 를 신청 하고 hep 의 새 brk 주 소 를 되 돌려 야 합 니 다.
void *mmap(void *addr, size\_t length, int prot, int flags, int fd, off\_t offset);
함 수 는 디스크 파일 을 메모리 에 비 추고 메모리 수정 을 하면 DISK 를 조작 할 수 있 습 니 다.여기 서 분 배 된 것 은 가상 메모리 일 뿐 입 니 다.사용 한 페이지 가 끊 겼 을 때 만 운영 체제 에서 분 배 를 하고 맵 을 만 듭 니 다.
malloc 할당 규칙
128k
메모리 보다 적 게 신청 할 때 malloc 는brk()
메모리 할당128k
보다 큰 메모 리 를 신청 할 때 malloc 는mmap()
메모리 배분이 이 유 는 brk()가 할당 한 메모리 가 높 은 주소 의 메모리 가 낮은 주소 로 풀 려 나 야만 풀 릴 수 있 기 때문이다.mmap 가 신청 한 메모 리 는 단독으로 방출 할 수 있 습 니 다.
이 럴 때 문 제 를 일 으 킬 수 있어 요.
바로 우리 가 자주 malloc 를 호출 할 때 위의 함수 중 하 나 를 호출 합 니 다.이런 것들 은 시스템 비용 이 발생 하 는 동시에 대량의 메모리 파편 도 발생 합 니 다.이 럴 때 메모리 관리 에 도움 을 주 고 메모리 조각 을 줄 일 수 있 는 메모리 탱크 가 필요 합 니 다.
메모리 탱크
메모리 탱크 는 사실 큰 메모 리 를 힙 구역 으로 작은 신청 한 다음 에 큰 메모 리 를 작은 메모리 로 나 누 어 사용자 가 메모 리 를 신청 할 때 적당 한 빈 블록 을 직접 분배 하 는 것 이다.암시 적 링크 를 사용 하여 많은 남 은 메모리 블록 을 연결 합 니 다.모든 메모리 블록 안 은 연속 적 인 메모리 입 니 다.
여 기 는 16 개의 링크 를 유지 하고 있 으 며,모든 링크(양 방향 링크)는 서로 다른 고정 크기 의 메모리 블록 을 유지 하고 있다.
c++의 malloc 바 텀 구현 코드 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 c+malloc 바 텀 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
hdu 1717 소수 화 점수 2 (수학)소수 화 점수 2 레이 는 수학 시간 에 선생님 의 말씀 을 듣 고 모든 소수 가 점수 로 표시 되 는 형식 이 라 고 말 했다. 그 는 녹 기 시 작 했 고 곧 완성 되 었 다. 그러나 그 는 또 하나의 문 제 를...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.