BRONZE
BRONZE 등급의 판매자 자료

AST를 다시 UCODE로 제작하는 프로그램

컴파일러 - 오세만 교수님 수업시간에 과제로 출제된 AST를 다시 Ucode로 제작하는 프로그램을 만드는 것입니다.
42 페이지
한컴오피스
최초등록일 2010.11.24 최종저작일 2009.09
42P 미리보기
AST를 다시 UCODE로 제작하는 프로그램
  • 미리보기

    소개

    컴파일러 - 오세만 교수님 수업시간에 과제로 출제된 AST를 다시 Ucode로 제작하는 프로그램을 만드는 것입니다.

    목차

    1. 과제에 대한 설명

    2. Execution Result
    인터프리터 실행 결과
    인터프리터 결과파일

    3. 프로그램에 대한 평가 및 소감

    4. Source Code

    본문내용

    1. 과제에 대한 설명
    지난 숙제까지 구현했던 AST를 이용하여 Ucode로 번역하는 프로그램을 작성하였다. AST까지 구현하는 방법을 생략하고, AST를 이용하여 Ucode를 생성시키는 프로그램에 대해서만 설명한다. LRParser를 확장하여, AST parser를 제작하였다. 이번 과제는 이 AST를 다시 Ucode로 제작하는 프로그램을 만드는 것이다. Ucode로 제작하기 위해서 Symbol을 저장하는 Symbol 테이블 데이터 구조가 있어야 한다. ICG를 구현하는데 필요한 대부분의 소스코드가 책에 있으나, 심볼테이블 구현에 대한 내용은 나와 있지 않아서, 심볼 테이블에 대한 제작은 책에 있는 내용을 기반으로 제작하였다. 사용된 심벌테이블은 스택 구현 해시 구조 심벌테이블로 제작하였다. 이 구조에서 책에 해시 버켓은 해시 값에 따른 심벌 테이블을 가리키고 있으며, 레벨 테이블은 스택처럼 운영된다. 그 값은 한 블럭의 첫번째 심벌의 위치를 가리킨다. 한 블록으로 들어갈 때, 레벨 테이블에 그 위치를 저장하고, 심벌이 정의되는 순서로 해시 함수 값에 의해 자신의 스택 영역에 차례로 삽입된다. 삽입될 때 충돌이 일어나면 후방법을 이용하여 해결한다. 한 블록이 처리된 후 그 블록을 빠져나올 때, 레벨 테이블에 저장된 위치를 이용하여 그 블록 내에서 정의된 모든 심벌을 제거한다. set 연산은 새로운 블록에 들어갈 때, 레벨 테이블의 top에 심벌테이블의 이용가능한 위치를 나타내는 avail값을 보관함으로써 해결되나, reset 연산은 한 블록이 완전히 컴파일 되었을 때 그 블록과 관계되는 레코드를 제거하는 일인데, 블록 간에 명칭 충돌 현상에 의해 만들어진 해시 버켓의 내용을 갱신하는 일이 추가되어야 한다.
    emit 관련된 파트와 해시테이블 구현을 제외하고는 거의 대부분의 소스가 책에서 발췌되었고, C에서 CLASS 개념을 도입하여, C++로 제작하였다. 프로그램의 실행은
    실행파일이름 perfect.mc < perfect.mc
    로 하였다.
    어떻게 실행해야 할지 잘 몰라. 위와 같이 실행하여 결과를 얻어냈다.(ICG를 실행할 때).

    참고자료

    · 없음
  • 자료후기

    Ai 리뷰
    판매자가 제공한 자료는 체계적인 구성으로 되어 있어 복잡한 내용을 과제에 쉽게 활용 할 수 있었습니다. 앞으로도 이러한 좋은 자료들이 많이 등록되기를 기대합니다.
    왼쪽 화살표
    오른쪽 화살표
  • 자주묻는질문의 답변을 확인해 주세요

    해피캠퍼스 FAQ 더보기

    꼭 알아주세요

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