PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2016/06/07 22:48:28
Name iMac
Subject [질문] 뮤텍스 & 세마포어에 대해서
OS 공부하다가 책을봐도 이해가 안가는 부분이 있어서 질문글 올립니다.

뮤텍스나 세마포어 둘다 critical section problem을 방지하기위해 사용하는 거잖아요?

근데 뮤텍스는 이해가 가겠습니다.

화장실이 1개이고 열쇠도 1개인 거죠

근데 세마포어는 여러개의 thread 에 대해서 하나의 resource에 대해서 유한한 갯수의 thread가 접근하는게끔  한다는 것 같은데 (count 해서 0되면 막고 등등)


그럼 결국에는 하나의 resource에 대해서  동시 접근이 가능하다는 소리 아닌가요?

세마포어가 어떻게 critical section problem을 해결하는 지 궁금합니다.

감사합니다

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
Je ne sais quoi
16/06/07 23:38
수정 아이콘
제가 예전에 했던 걸 다 까먹어서 지금 정확히 기억이 안 나는데(틀리면 다른 분들이 정정해주실 겁니다 -_-;;)...
semaphore는 실행하는 thread들이 서로 알고 맞춰서(표현을 좀 더 정확히 해야 할텐데 -_-a) 동작을 해야 할겁니다. 그걸 사용자가 할 수 없어서, OS가 제공하는 함수를 사용해야 합니다. 리눅스, 윈도우 등등 OS따라 다를 거예요.
16/06/08 00:11
수정 아이콘
주활용 용도가 조금 다르기는 한데, 뮤텍스는 적어주신 단일 리소스에 대해 쓰기를 하는 경우에 대한 동기화를 보장하기 위해 많이 사용하고, 세마포어를 일반적으로 사용하는 경우는 여러 개의 리소스(예: DB 커넥션 풀 등)에 동시에 접근하는 스레드의 수를 제한하는 경우에 많이 사용됩니다. 그런데 세마포어로 접근을 허용한 여러개의 쓰레드 중 쓰기를 하는 쓰레드가 따로 있다면 쓰기를 하는 부분에 다시 세마포어를 1로 설정하거나 뮤텍스를 걸거나 내부에 다시 critical section을 만들어서 동기화를 보장하도록 하는 것도 가능합니다.
Patrick Jane
16/06/08 01:31
수정 아이콘
세마포어를 4개의 화장실과 4개의 열쇠라고 생각하시면 될거 같아요. 공유자원의 갯수가 1인 세마포어 = 뮤택스인걸로 알고있습니다만... 만약 틀리다면 다른분들이 정정을 해주시겠....
16/06/08 03:26
수정 아이콘
우선 세마포어는 critical section을 만들기 위해 쓰는게 아니구요. 그래서 바이너리 세마포어 제외하면 잘 안 씁니다.
16/06/08 09:20
수정 아이콘
답변해주신분들감사합니다
잉여의슬픔
16/06/08 20:52
수정 아이콘
위에 Unikys님 설명해주신 게 정확한 것 같아요. 대체로 1. 카운트를 1로 설정하면 뮤텍스 처럼 쓸 수 있고 2. 공유된 resource pool 같은 것에 카운트를 총 리소스 수로 설정해서 쓸 수 있고 3. 쓰레드간 signalling으로 쓰일 수 있습니다. 순서가 1번 프로세스가 먼저 실행된 다음에 2번이 실행돼야하면 1번은 V하고 2번은 P하는 식으로요. 여기 정리가 잘 돼있습니다. http://www.cs.cornell.edu/Courses/cs4410/2015su/lectures/lec07-sema.html
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
84381 [질문] Evernote의 장점은 뭔가요? [12] 꾸꾸3218 16/06/08 3218
84380 [질문] 기침및 목이 아픈데 미세먼지 때문인가요? [2] 레인이2275 16/06/08 2275
84379 [질문] 자연사하는 동물이 얼마나 있나요? [7] 하카세3106 16/06/08 3106
84378 [질문] 단축마라톤 정보는 어디서 얻나요? [6] 밴픽1961 16/06/08 1961
84377 [질문] [오버워치] 맵 어떻게 익히나요? [14] Mosby6236 16/06/08 6236
84376 [질문] 스마트폰 잘 관리하는 방법? [9] 마이스타일2614 16/06/08 2614
84375 [질문] 조립pc 이 조합 어떤가요? [21] RookieKid3840 16/06/08 3840
84374 [질문] [수학]기울어진 타원의 방식은 어떻게 되나요? [4] 낙화14411 16/06/08 14411
84373 [질문] 비주얼 스튜디오2015 런타임 오류때문에 (수정) [3] 물리쟁이2890 16/06/08 2890
84372 [질문] 렌트카 접촉사고에 대해 질문드립니다. [4] 카푸치노2790 16/06/08 2790
84371 [질문] 아이폰se는 sk로밖에 안나오나요?? [2] chamchI2122 16/06/08 2122
84370 [질문] 사이판 괌 여행질문입니다. 그리고 삿포로. [9] 미스서2581 16/06/08 2581
84369 [질문] 영어 공부를 하고 싶습니다. [3] 달보드레1936 16/06/08 1936
84368 [질문] 옷 스타일을 캐쥬얼로 갈아타고 싶습니다. [4] Secundo2887 16/06/08 2887
84367 [질문] 다리가 풀릴 정도로 어지럽고 심각한 두통 [9] 학자3055 16/06/08 3055
84366 [질문] 런던행 비행기 티켓값 이 정도면 비싼가요? [13] Liverpool FC4032 16/06/08 4032
84365 [질문] 멀티탭을 잘못 건들어서 컴퓨터가 꺼진다음 다시 켜지지 않습니다. [3] 카서스2180 16/06/08 2180
84364 [질문] 안드로이드 폰 전원 버튼으로 전화 받으려면? [3] CLAMP 가능빈가1890 16/06/08 1890
84363 [질문] [피온3] 노래가 궁금합니다. 어찌하리까1431 16/06/08 1431
84362 [질문] 헤드폰 질문드립니다 [3] 삐니키니1460 16/06/08 1460
84361 [질문] 팔운동 질문입니다 [6] 문법나치2549 16/06/08 2549
84360 [질문] 신용카드 해외원화결제 수수료 관련 질문입니다. [6] peony2868 16/06/08 2868
84359 [질문] 오버워치 및 장르별 보는 재미? [21] 엔비3428 16/06/08 3428
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로