단축키

Prev이전 문서

Next다음 문서

수정 삭제

단축키

Prev이전 문서

Next다음 문서

수정 삭제
Extra Form

메모리 누수 를 감지하고 문제를 해결할 때 몇 가지 유용한 도구를 선택해야 합니다.dmalloc은 컴파일이 복잡하고 valgrind에 너무 많이 의존하기 때문에 gcc의 자체 메모리 누수 감지 도구와 함께 제공되는 asan을 사용하기로 선택합니다.

 

Asan은 버전 4.8 이후에 지원됩니다. 아래에서 사용해보자 효과를 보자.

 

의존 하는 asan 라이브러리 설치 : libasan.so yum 설치 libasan ce:normal">

매개변수 : -fsanitize=주소 -fno-생략-프레임 포인터 -g -O2 tion-style:initial">

이 기능은 런타임 감지이며 실행되지 않는 코드는 감지할 수 없습니다. 범위를 벗어난 메모리

 

int fun0(){
char str[4] = {0,};
strcpy(str,"测试");
return 0;
}
=================================================================
==12724== ERROR: AddressSanitizer: stack-buffer-overflow on address 0x7ffe1ac0d566 at pc 0x4008d3 bp 0x7ffe1ac0d530 sp 0x7ffe1ac0d520
WRITE of size 1 at 0x7ffe1ac0d566 thread T0
    #0 0x4008d2 (/home/yubo.wang/4g-box/func-call/a.out+0x4008d2)
    #1 0x7f82632a9444 (/usr/lib64/libc-2.17.so+0x22444)
    #2 0x400931 (/home/yubo.wang/4g-box/func-call/a.out+0x400931)
Address 0x7ffe1ac0d566 is located at offset 38 in frame <main> of T0's stack:
  This frame has 1 object(s):
    [32, 36) 'str'
HINT: this may be a false positive if your program uses some custom stack unwind mechanism or swapcontext
      (longjmp and C++ exceptions *are* supported)
Shadow bytes around the buggy address:
  0x100043579a50: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579a60: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579a70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579a80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579a90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
=>0x100043579aa0: 00 00 00 00 00 00 00 00 f1 f1 f1 f1[04]f4 f4 f4
  0x100043579ab0: f3 f3 f3 f3 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579ac0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579ad0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579ae0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100043579af0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
Shadow byte legend (one shadow byte represents 8 application bytes):
  Addressable:           00
  Partially addressable: 01 02 03 04 05 06 07 
  Heap left redzone:     fa
  Heap righ redzone:     fb
  Freed Heap region:     fd
  Stack left redzone:    f1
  Stack mid redzone:     f2
  Stack right redzone:   f3
  Stack partial redzone: f4
  Stack after return:    f5
  Stack use after scope: f8
  Global redzone:        f9
  Global init order:     f6
  Poisoned by user:      f7
  ASan internal:         fe
==12724== ABORTING

 

메모리 누수

 

char *fun1(char *str) {
static char *p;
p = malloc(64);
strcpy(p,str);
return p;
}
 
int fun2(){
char *str=fun1("abcd");
printf("str=%sn",str);
return 0;

 

 

메모리 누수가 감지되지 않았습니다.

불법 메모리

int fun3(){
char *p = NULL;
strcpy(p,"a");
return 0;
}
ASAN:SIGSEGV
=================================================================
==12787== ERROR: AddressSanitizer: SEGV on unknown address 0x000000000000 (pc 0x00000040081c sp 0x7ffc02097320 bp 0x7ffc02097320 T0)
AddressSanitizer can not provide additional info.
    #0 0x40081b (/home/yubo.wang/4g-box/func-call/a.out+0x40081b)
    #1 0x7f7be5ab3444 (/usr/lib64/libc-2.17.so+0x22444)
    #2 0x4008b1 (/home/yubo.wang/4g-box/func-call/a.out+0x4008b1)
==12787== ABORTING

 

 

요약하다

san은 out-of-bounds 및 잘못된 메모리를 감지할 수 있지만 malloc과 free의 일치는 감지할 수 없습니다.

크로스 컴파일 체인을 사용하여 컴파일해야 하는 경우 크로스 도구 체인에서 libasan.so 라이브러리를 지원해야 합니다.

 


0 0 0 0 0 0 0 1 2 0 0 0 0 0 0 0 0 1 1 1
List of Articles
번호 분류 제목 글쓴이 조회 수 날짜
공지 뉴스 구글 최신 뉴스 file 덕후냥이 1425 2024.12.12
공지 🚨(뉴비필독) 전체공지 & 포인트안내 8 file 무명의덕질 25987 2024.11.04
공지 URL만 붙여넣으면 끝! 임베드 기능 무명의덕질 20464 2025.01.21
10642 일반 Synology의 4 베이 NAS 장비 "DiskStation DS416j" 덕후냥이 1462 2016.02.08
10641 일반 태블릿 PC의 충전을하면서 주변 기기를 사용할 수있는 OTG 지원 USB 허브 덕후냥이 1445 2016.02.08
10640 일반 카페베네 상장 난항에 투자자 눈물 덕후냥이 783 2016.02.15
10639 일반 주식, 욕심은 화를 부르고. 그 화는 고스란히 가족들에게 짜증을 부릴겁니다 덕후냥이 797 2016.02.22
10638 일반 원익IPS 추천합니다 덕후냥이 681 2016.02.22
10637 일반 장이 너무 안좋네요 ㅜㅜ 덕후냥이 714 2016.02.22
10636 일반 주식투자와 관련된 주식명언 덕후냥이 1006 2016.02.22
10635 일반 i5-6600 i5-6500 비교 1 덕후냥이 1441 2016.02.22
10634 일반 ssd좀봐주세요 2 덕후냥이 913 2016.02.27
10633 일반 크라운제과 어떻게 보시나요? 덕후냥이 462 2016.02.28
10632 일반 흑자예상하며 기다린보람이 있군 덕후냥이 476 2016.02.28
10631 일반 세계 주식 주요 지수 보는곳 입니다.모르시는분들을 위해 덕후냥이 649 2016.02.28
10630 일반 한 2월 말쯤 총선테마가 시작될걸로 예상합니다. 덕후냥이 567 2016.02.28
10629 일반 대중관계 악화로 중국에서 돈버는 기업들 급락이네요 덕후냥이 690 2016.02.28
10628 일반 주식 생초보인데 알려주실수 있으신가요? 덕후냥이 519 2016.02.28
10627 일반 11시정도만 잘 넘기면 될거같은데.. 덕후냥이 481 2016.02.28
10626 일반 요즘 한종목에 꽂혀서 분할매수하는데요. 덕후냥이 568 2016.02.28
10625 일반 본인 명의로 핸드폰 두개 개설 하면 문제 생기나요? 1 덕후냥이 1160 2016.03.01
10624 일반 단말기대금 일시불납 가능한가요? 1 덕후냥이 781 2016.03.05
10623 일반 노트4 배터리 공유?? 1 덕후냥이 1749 2016.03.05
Board Pagination Prev 1 2 3 4 5 ... 533 Next
/ 533