BRONZE
BRONZE 등급의 판매자 자료

(운영체제) posix thread를 사용한 교차로 구현- 설계보고서

posix thread를 사용하여 교차로의 교통량 문제를 해결하는 문제입니다. 교차로에는 서로 다른 방향의 차량이 동시에 들어와 충돌이 발생하거나 서로의 진행 방향을 방해하여 교차로가 혼잡하거나 꽉 막힌 상태가 발생할 수도 있습니다. 따라서 충돌을 방지하며 데드락이 발생하지 않도록 효과적인 교차로를 구현하는 것이 목적입니다. - 제한 사항- 1. 교차로의 각 부분(nw, ne, sw, se)에는 총 4대의 차량이 존재할 수 있습니다. 2. 차량들은 하나의 thread가 담당하게 됩니다. 3. 함수의 프로토 타입 및 일부 함수 구현을 제공하며 제공된 코드는 수정할 수 없습니다. 4. 교차로를 효율적으로 구현하는 것이 목적이며 데드락이 발생해서는 안됩니다. car_driving()함수와 각 교차로 구간의 queue 정책에 대한 서술 위주의 설계 보고서입니다.
18 페이지
워드
최초등록일 2013.05.25 최종저작일 2012.09
18P 미리보기
(운영체제) posix thread를 사용한 교차로 구현- 설계보고서
  • 미리보기

    소개

    posix thread를 사용하여 교차로의 교통량 문제를 해결하는 문제입니다.
    교차로에는 서로 다른 방향의 차량이 동시에 들어와 충돌이 발생하거나 서로의 진행 방향을 방해하여 교차로가 혼잡하거나 꽉 막힌 상태가 발생할 수도 있습니다. 따라서 충돌을 방지하며 데드락이 발생하지 않도록 효과적인 교차로를 구현하는 것이 목적입니다.

    - 제한 사항-
    1. 교차로의 각 부분(nw, ne, sw, se)에는 총 4대의 차량이 존재할 수 있습니다.
    2. 차량들은 하나의 thread가 담당하게 됩니다.
    3. 함수의 프로토 타입 및 일부 함수 구현을 제공하며 제공된 코드는 수정할 수 없습니다.
    4. 교차로를 효율적으로 구현하는 것이 목적이며 데드락이 발생해서는 안됩니다.

    car_driving()함수와 각 교차로 구간의 queue 정책에 대한 서술 위주의 설계 보고서입니다.

    목차

    1.설계 주제
    2.설계 개요
    3.설계 알고리즘
    4. 설계 코드 구현
    5.설계 결과 출력화면

    본문내용

    - MUTEX

    Mutual Exclusion(상호 배제)의 뜻으로써 Critical Section(임계 구역)문제를 해결하기 위한 방법 중 하나이다. 뮤텍스 개체는 잠겨지지 않은 Unlock 상태와 잠금 Lock 상태, 두 가지의 상태를 가지며 둘 이상의 스레드가 소유할 수 없다.
    다수의 객체가 공유자원에 접근하려고 할 시 접근 시점을 제어해야 한다. 시간과 공간을 맞추어준다는 의미의 동기화 해야함으로써 공유 자원 영역에 접근하는 객체들의 진입 시간을 제어해준다.

    <중 략>

    교차로마다 생성한 count 변수를 0으로 초기화 해놓음
    랜덤으로 자동차 방향과 이동 방향 생성한 것을 통하여 첫 번째 스레드가 임계 영역에 진입
    다른 스레드들이 같은 교차로에 진입하고자 할 경우 임계 영역 진입을 시도하지만 이미 첫 번째 스레드가 진입해 있으므로 임계 영역 밖에서 대기
    첫 번째 스레드가 count 값을 읽고 카운팅 연산한 후 값을 증가 시켜 저장함
    첫 번째 스레드가 일 수행을 마친 후 임계 영역에서 빠져 나옴
    그로써 다음 스레드가 임계 영역에 진입하여 count 값 읽어 카운팅 연산한 후 저장함

    <중 략>

    switch(car_direction) //현재 위치 파악
    {
    case OS_HW_SOUTH: //남쪽에서 오는 경우
    switch(turn_direction) //앞으로 나아갈 방향 파악
    {
    case OS_HW_WEST: //남->서 경우, se->ne->nw
    pthread_mutex_lock(&mutex_m_se); //첫 번째 지나가는 경로인 se 교차로 mutex lock

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자가 등록한 자료는 과제에 적용할 수 있는 유용한 내용이 많아, 큰 도움이 되었습니다. 앞으로도 많은 도움을 받을 수 있기를 기대합니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

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