[완료]sbrk()함수에 대한 궁금증..
글쓴이: lucadi / 작성시간: 월, 2008/06/16 - 9:51오후
computer systems [a programmer's perspective]란 책을 보고 있는데요..
dynamic memory allcation 관련 부분중에서..
malloc함수는 내부적으로 mmap, munmap 또는 sbrk()를 이용한다고 해서..
printf("%d\n", malloc(5*sizeof(int));
printf("%d\n", malloc(4*sizeof(int));
printf(%d\n, p1);
printf(%d\n, p2);
printf(%d\n, sbrk(0));
라고 작성해서 프로그램을 돌렸더니.
134520840
134520864
134656000
이라고 결과가 나왔습니다..
malloc 함수가 sbrk()을 이용한다고 나온것처럼, sbrk(0)이 heap의 최상위의 brk를
리턴해준다면, 마지막 출력은 134520880이 나와야 하는 것이 아난가요?
분명 제가 많이 잘못 이해한것 같은데요..
어디서 부터 잘못 이해했는지 잘모르겠습니다..
Forums:
malloc() 알고리즘에
malloc() 알고리즘에 따라 다릅니다. brk()로 받을꺼면 매번 brk()로 받는경우도 있겠지만, brk()로 수 메가씩 미리 받아놓은 다음 할당요청할때마다 brk()없이 이전에 받은 메모리를 사용하는 경우도 있습니다.
그리고 sbrk(0)은 프로그램이 사용하는 데이터 영역의 끝 주소를 리턴합니다.
Written By the Black Knight of Destruction
Written By the Black Knight of Destruction
데이터 영역의 끝 주소라는게..
데이터 영역의 끝 주소라는게 어느 영역을 말하는 건가요?
가상 주소를 보면,
User stack
heap
.bss
.data
.text
의 형태로 되어있는데요..
그렇다면, sbrk(0)는 .bss(uninitialized data)의 끝 주소를 리턴하는 건가요?
개인적으로 heap도 동적 데이터 영역이라고 생각해서...sbrk(0)가 heap의 끝부분을
리턴하는 것으로 생각하고 있습니다..
malloc을 부르면 system
malloc을 부르면 system library가 알아서 sbrk를 불러서 넉넉하게 받아놓은 다음, 차후 malloc이 들어올 때마다 미리 받아온 공간에서 잘라줍니다. 따라서 malloc으로 받아온 영역의 끝부분과 커널이 sbrk로 준 영역의 끝부분은 일반적으로 일치하지 않습니다.
그렇게 안 하면 malloc을 한번 부를 때마다 kernel system call을 부르는 오버헤드가 생기겠죠.
아.그렇군요..감사합니다..
..
댓글 달기