• AI글쓰기 2.1 업데이트
BRONZE
BRONZE 등급의 판매자 자료
non-ai
판매자가 AI를 사용하지 않은 독창적인 자료

malloc lab - implicit list (간접 리스트) 방식 해결방법에 대한 보고서

★과제할 때 참고만하시고 !!!! 열공하세요!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!★ 전자정보통신공학부의 운영체제 , unix 프로그래밍 , 시스템 프로그래밍 과제로 나오는 malloc lab (말록 랩) 의 제공 되어지는 mm-naive.c 설명과 + implicit list 에 대한 해설을 매우 자세하게 기록했던 보고서입니다. (가산점)
22 페이지
한컴오피스
최초등록일 2012.08.28 최종저작일 2012.06
22P 미리보기
malloc lab - implicit list (간접 리스트) 방식 해결방법에 대한 보고서
  • * 본 문서는 한글 2005 이상 버전에서 작성된 문서입니다. 한글 2002 이하 프로그램에서는 열어볼 수 없으니, 한글 뷰어프로그램(한글 2005 이상)을 설치하신 후 확인해주시기 바랍니다.

    미리보기

    소개

    ★과제할 때 참고만하시고 !!!! 열공하세요!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!★
    전자정보통신공학부의
    운영체제 , unix 프로그래밍 , 시스템 프로그래밍 과제로 나오는 malloc lab (말록 랩) 의
    제공 되어지는 mm-naive.c 설명과 + implicit list 에 대한 해설을 매우 자세하게 기록했던 보고서입니다. (가산점)

    목차

    제공 되어지는 mm-naive.c 설명
    mm-implicit.c 구현 설명
    1. 이 과제의 목표
    2. Hint 매크로 설명
    3. 구현 함수 소스와 설명

    본문내용

    제공 되어지는 mm-naive.c 설명
    ★ Macro 설명
    /* If you want debugging output, use the following macro. When you hand
    * in, remove the #define DEBUG line. */
    #define DEBUG
    #ifdef DEBUG
    # define dbg_printf(...) printf(__VA_ARGS__)
    #else
    # define dbg_printf(...)
    #endif
    ▶ #ifdef DEBUG 는 DEBUG가 #define문으로 정의가 되어있을 경우, 그 밑에 #else 전까지의 라인인 # define dbg_printf(...) printf(__VA_ARGS__) 를 포함시켜주고, 그 다음 #esle에서는 DEBUG가 #define문으로 정의 되어있지 않은 경우에 그 밑 라인인 # define dbg_printf(...)를 포함 시켜주라는 전처리기 지시어입니다. 이 소스에서는 맨 처음에 #define DEBUG으로 DEBUG가 define 되어있으므로 #ifdef DEBUG 와 #else 사이의 # define dbg_printf(...) printf(__VA_ARGS__)이 포함되게 되는 것 같습니다..

    <중 략>

    네 번째 케이스의 경우인 bp가 가리키는 블록의 앞, 뒤 블록이 모두 free한 경우에는 이전 블록과 다음 블록의 size과 bp가 가리키는 블록의 size를 모두 정하여 이전블록의 헤더와 다음 블록의 푸터에 넣어줍니다. 합해진 후에는 bp는 이전블록의 포인터가 됩니다.

    그리고 bp를 리턴해줍니다.
    free 함수

    할당된 메모리를 해제하는 함수인 free함수는 가장 먼저 ptr이 NULL일 경우에는 아무 일도 안하고 종료하게 됩니다. ptr이 존재할 경우, ptr이 가리키는 블록의 헤더에서 사이즈를 읽어와서 size_t size에 저장해줍니다. 그리고 heap_listp가 0인 경우에는 mm_init함수를 호출하여 초기화를 다시 실행해줍니다. (책에도 나와있지 않고 지워도 이상 없었음... 혹시 모르는 상황을 대비하는 부분인 듯??) 그 후, ptr의 헤더에 아까 읽어온 사이즈 값과 할당 안 했다는 표시인 0을 PACK해서 넣어줍니다. 그리고 ptr의 푸터에도 동일하게 넣어줍니다. free했을 경우, 앞 뒤 블록이 free할 경우를 생각해서 연결해줘야 하므로, coalesce함수를 호출해줍니다.
    <- coalesce함수
    그리고 리턴되는 free한 블록의 시작 부분을 가리키는 포인터를 temp_ptr에 넣어줍니다. 이는 find_fit에서 free한 블록부터 검색을 시작하게 해줍니다.

    참고자료

    · Computer systems
  • 자료후기

      Ai 리뷰
      지식판매자가 등록한 자료는 과제에 직접 활용할 수 있는 유용한 내용이 많아, 큰 도움이 되었습니다. 앞으로도 계속 좋은 자료 부탁드립니다! 감사합니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우
    문서 초안을 생성해주는 EasyAI
    안녕하세요 해피캠퍼스의 20년의 운영 노하우를 이용하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 AI가 방대한 정보를 재가공하여, 최적의 목차와 내용을 자동으로 만들어 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 이용권를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2026년 02월 02일 월요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    3:47 오전