컴퓨터/노트북/인터넷
IT 컴퓨터 기기를 좋아하는 사람들의 모임방
🕰️
2022.03.02 21:27
Linux gcc에는 메모리 누수를 감지하는 도구인 San이 함께 제공됩니다.
조회 수 44 추천 수 0 댓글 0
메모리 누수 를 감지하고 문제를 해결할 때 몇 가지 유용한 도구를 선택해야 합니다.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
요약하다
컴퓨터/노트북/인터넷
IT 컴퓨터 기기를 좋아하는 사람들의 모임방
번호 | 분류 | 제목 | 조회 수 | 날짜 |
---|---|---|---|---|
공지 | 뉴스 |
구글 최신 뉴스
![]() |
1384 | 2024.12.12 |
HOT글 | 일반 | 아 진짜 요새 SKT 해킹 뭐시기 때문에 신경 쓰여 죽겠어 ㅠㅠ 2 | 236 | 2025.05.20 |
공지 | 사랑LOVE 포인트 만렙! 도전 | 4651 | 2025.03.19 | |
공지 | 🚨(뉴비필독) 전체공지 & 포인트안내 2 | 25846 | 2024.11.04 | |
공지 | URL만 붙여넣으면 끝! 임베드 기능 | 20431 | 2025.01.21 | |
10640 | 일반 | Synology의 4 베이 NAS 장비 "DiskStation DS416j" | 1456 | 2016.02.08 |
10639 | 일반 | 태블릿 PC의 충전을하면서 주변 기기를 사용할 수있는 OTG 지원 USB 허브 | 1434 | 2016.02.08 |
10638 | 일반 | 카페베네 상장 난항에 투자자 눈물 | 776 | 2016.02.15 |
10637 | 일반 | 주식, 욕심은 화를 부르고. 그 화는 고스란히 가족들에게 짜증을 부릴겁니다 | 789 | 2016.02.22 |
10636 | 일반 | 원익IPS 추천합니다 | 676 | 2016.02.22 |
10635 | 일반 | 장이 너무 안좋네요 ㅜㅜ | 707 | 2016.02.22 |
10634 | 일반 | 주식투자와 관련된 주식명언 | 999 | 2016.02.22 |
10633 | 일반 | i5-6600 i5-6500 비교 1 | 1434 | 2016.02.22 |
10632 | 일반 | ssd좀봐주세요 2 | 906 | 2016.02.27 |
10631 | 일반 | 크라운제과 어떻게 보시나요? | 458 | 2016.02.28 |
10630 | 일반 | 흑자예상하며 기다린보람이 있군 | 471 | 2016.02.28 |
10629 | 일반 | 세계 주식 주요 지수 보는곳 입니다.모르시는분들을 위해 | 646 | 2016.02.28 |
10628 | 일반 | 한 2월 말쯤 총선테마가 시작될걸로 예상합니다. | 562 | 2016.02.28 |
10627 | 일반 | 대중관계 악화로 중국에서 돈버는 기업들 급락이네요 | 684 | 2016.02.28 |
10626 | 일반 | 주식 생초보인데 알려주실수 있으신가요? | 515 | 2016.02.28 |
10625 | 일반 | 11시정도만 잘 넘기면 될거같은데.. | 478 | 2016.02.28 |
10624 | 일반 | 요즘 한종목에 꽂혀서 분할매수하는데요. | 565 | 2016.02.28 |
10623 | 일반 | 본인 명의로 핸드폰 두개 개설 하면 문제 생기나요? 1 | 1154 | 2016.03.01 |
10622 | 일반 | 단말기대금 일시불납 가능한가요? 1 | 781 | 2016.03.05 |
10621 | 일반 | 노트4 배터리 공유?? 1 | 1749 | 2016.03.05 |
10620 | 일반 | 금호타이어 어떻게 보시나요? | 650 | 2016.03.05 |
10619 | 일반 | 해외에서 사용하던 도메인을 구입했는데 헉.. | 568 | 2016.03.09 |
10618 | 일반 | 축구 페널티킥 선방 탑10 | 469 | 2016.03.12 |
10617 | 일반 | SSD의 성능을 유지하기위한 유지 관리 기술 | 1068 | 2016.03.15 |
10616 | 일반 | 저렴한 Skylake 버전 Xeon 마더보드 'GA-X150M-PRO ECC」 | 874 | 2016.03.15 |
10615 | 일반 | G5 vs S7 1 | 626 | 2016.03.18 |
10614 | 일반 | 스테레오믹스 소리가 안납니다 1 | 1104 | 2016.03.19 |
10613 | 일반 | 스피커를 항상 켜 놓는데요. 노이즈??? 소리가 납니다. 1 | 850 | 2016.03.19 |
10612 | 일반 | M2 메모리 추천 1 | 911 | 2016.03.19 |
10611 | 일반 | 모니터 단자 HDMI, DP & 오디오 관련 문의 1 | 865 | 2016.03.19 |