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

Semaphore를 이용한 Bounded buffer

Semaphore를 이용한 bounded buffer 프로그램입니다.. producer와 comsumer task를 thread와 process로 각각 구현해보았습니다.. 이 프로그램은 Linux 상에서 구현된 코드입니다.. gcc 컴파일러를 통해 컴파일 하시기 바랍니다.. 운영체제를 공부하는 학생분들에게 많은 도움이 되었으면 좋겠습니다..
12 페이지
압축파일
최초등록일 2007.11.29 최종저작일 2006.05
12P 미리보기
Semaphore를 이용한 Bounded buffer
  • 미리보기

    소개

    Semaphore를 이용한 bounded buffer 프로그램입니다..
    producer와 comsumer task를 thread와 process로 각각 구현해보았습니다..
    이 프로그램은 Linux 상에서 구현된 코드입니다..
    gcc 컴파일러를 통해 컴파일 하시기 바랍니다..
    운영체제를 공부하는 학생분들에게 많은 도움이 되었으면 좋겠습니다..

    목차

    과제: Semaphore를 이용하여 Bounded buffer problem을 프로그램으로 구현하라.
    target#1 Bounded buffer의 producer-consumer를 thread로 구현하라.
    *프로그램 동작개요
    *프로그램 코드

    target#2 Process를 이용하여 Bounded buffer를 구현하라.
    *프로그램 동작개요
    *프로그램 코드

    본문내용

    target#1 Bounded buffer의 producer-consumer를 thread로 구현하라.

    Producer와 Consumer는 shared 영역인 Bounded buffer를 두고 semaphore통해 동기화 되고 병행처리 될 수 있어야 한다. 그러기 위해서는 서로 독립된 일을 수행할 수 있어야 하는데 multi-threaded program의 개념을 통해 쉽게 구현 될 수 있다.
    독립된 일을 수행하기 위해서 multi-processed program을 이용해서 구현 할 수 있지만 process에 비해 thread가 가볍고 data의 공유가 쉽기 때문에 Bounded buffer 정도의 가벼운 프로그램의 경우 thread를 이용하는 방법이 적합한 방법이라고 할 수 있다.

    프로그램 동작개요
    1. Main Process에서 producer thread와 consumer thread를 생성한다.
    2. Main Process에서 Semaphore를 구성한다.
    3. Thread 간에 Shared data는 buffer와 input, output counter이다.
    4. Producer는 input file에서 item을 하나씩 읽어 buffer에 저장한다.
    5. Consumer는 buffer에서 item을 읽어 output file에 출력한다.
    6. Producer는 input file에서 ‘;’을 두 번 읽을 경우 작업을 종료한다.
    7. Consumer는 ‘;’을 읽으면 작업을 종료한다.
    8. 모든 Thread가 종료되면 Main Process는 Terminated 된다.

    target#2 Process를 이용하여 Bounded buffer를 구현하라.

    앞서 말한바와 같이 process를 이용하는 방법보다 thread를 이용하는 방법이 훨씬 구현이 쉽고 간단하지만 shared memory와 IPC의 개념을 파악하기 위해서 process를 이용해 Bounded buffer를 구현해보도록 한다. Process의 경우 다른 Process와는 완전히 다른 영역에 Memory가 할당되기 때문에 data를 share하기 위해서는 shared memory를 이용해야 한다.

    참고자료

    · Operating System Principles 7ed. - Abraham Silberschatz, Peter Baer Galvin, & Greg Gagne
  • 자료후기

      Ai 리뷰
      지식판매자가 제공하는 자료는 질이 매우 높고, 주제에 대한 깊이 있는 분석이 인상적입니다. 이해하기 쉬운 설명과 다양한 예시 덕분에 활용하기 편했습니다. 정말 감사드립니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

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

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

    찾으시던 자료가 아닌가요?

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