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

컴파일러 (중위식을 후위식으로 변환하는 컴파일러 작성)

컴파일러 (중위식을 후위식으로 변환하는 컴파일러 작성)
17 페이지
한컴오피스
최초등록일 2010.03.28 최종저작일 2009.06
17P 미리보기
컴파일러 (중위식을 후위식으로 변환하는 컴파일러 작성)
  • 미리보기

    소개

    컴파일러 (중위식을 후위식으로 변환하는 컴파일러 작성)

    목차

    ※ 목적
    1. 최적화 된 소스 코드
    2. 최적화 된 실행 결과
    3. 내가 작성한 소스코드
    4. 내가 작성한 실행결과
    ※ 후기

    본문내용

    ※ 목적
    이 프로그램은 세미콜론으로 끝나는 연산식으로 이루어진 언어를, 중위식에서 후휘식으로 변환하는 기능을 갖고 있다. 연산식은 숫자와 식별자 그리고 연산자들 +, -, *, /, div 그리고 mod 등으로 구성된다. 프로그램은 모두 7개의 모듈로 구성되는데, 각각 다른 파일로 나누어져 있다. 실행은 main.c에 있는 모듈에서 시작되는데, 여기에서 초기화를 하는 init()를 부른 후에 번역을 하는 parse()를 부른다. global.h 헤더파일 + 나머지 6개의 모듈로 나누어진다. 아래의 모듈 그림을 보면 어떻게 전개되는지 대략적으로 알 수 있다.

    ① 형태소 분석기 모듈 lexer.c
    파서가 다음 토큰을 위해 이것을 호출한다. 이것은 매번 한 글자를 읽어 들여 토큰이 발견되면 그것을 파서에게 돌려준다. 각 토큰과 관련있는 속성 값은 전체 변수(gloval variable)인 tokenval에 넣는다. 심벌 테이블 루틴 lookup을 사용해서 어떤 식별자의 렉심이 이전에 있었는지를 검사하고 insert를 사용해서 새로운 렉심을 심벌 테이블에 저장한다. 또한 개행 문자를 발견하면 전체 변수인 lineno의 값을 증가시킨다.

    ② 파서 모듈 parser.c
    파서 모듈은 우리책의 기법을 이용하면 왼쪽 순환성을 제거한다. 그렇게 하면 기초 문법(underlying grammar)은 순환적 내림차순 파서(recursive-descent)에 의해서 처리될 수 있다. 함수 parse()는 문법의 시작 기호(start symbol)를 구현한 것이다. 이것은 새로운 토큰이 필요하면 lexan을 부른다. 이 파서에서는 결과를 생성하는데 함수 emit를 사용하고, 문법 오류를 출력하는데 함수 error를 사용하고 있다.


    ③ 결과 출력 모듈 emitter.c
    결과 출력 모듈은 한 개의 함수 emit(t, tval)로 구성되어 있는데, 이것은 토큰 t와 그것의 속성값 tval을 출력한다.


    ④ 심벌 테이블 모듈 symbol.c
    심벌 테이블 모듈 symbol.c는 배열 symtable의 각 원소는 배열 lexemes의 위치를 가리키는 포인터와 그곳에 저장되어 있는 토큰을 뜻하는 정수 값으로 구성되어 있다. 함수 insert(s, t)는 토큰 t와 렉심 s를 가져가서 symtable에서 찾아서 있으면 그 위치를 돌려주고 없으면 0을 돌려준다.

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자의 자료는 제가 필요로 하는 지식을 완벽하게 충족시켜주었습니다. 과제 제출일이 얼마 남지 않아 시간이 부족했는데, 이 자료 덕분에 과제를 제출 할 수 있었습니다. 정말 감사합니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

    함께 구매한 자료도 확인해 보세요!

    문서 초안을 생성해주는 EasyAI
    안녕하세요 해피캠퍼스의 20년의 운영 노하우를 이용하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 AI가 방대한 정보를 재가공하여, 최적의 목차와 내용을 자동으로 만들어 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 이용권를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2026년 01월 22일 목요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    10:13 오후