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
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
84361 [질문] 팔운동 질문입니다 [6] 문법나치2297 16/06/08 2297
84360 [질문] 신용카드 해외원화결제 수수료 관련 질문입니다. [6] peony2573 16/06/08 2573
84359 [질문] 오버워치 및 장르별 보는 재미? [21] 엔비3181 16/06/08 3181
84358 [질문] 개인사업자 등록관련 문의 드립니다 [7] RnR4666 16/06/08 4666
84357 [질문] 차량 선택 도와주세요~~ [4] 아슬란2846 16/06/08 2846
84356 [질문] 청주야구장 응원석이 어디인가요? [2] 사구삼진2515 16/06/08 2515
84355 [질문] 노트북 질문입니다!! [5] Hybrid1709 16/06/08 1709
84354 [질문] 트와이스에서 다현은 어느정도 위치인가요? [10] 카스트로폴리스6987 16/06/08 6987
84352 [질문] 파이어폭스 창이 자꾸만 사라집니다.(?) [2] 토다기1546 16/06/08 1546
84351 [질문] 영어 초보 회화 공부 방법 알려주셔요 [4] 대륙의지배자1931 16/06/08 1931
84350 [질문] 랜섬웨어 질문 [6] phoe菲1715 16/06/08 1715
84349 [질문] 트오세 요즘 어떤가요 할만한가요? [6] lenakim2855 16/06/08 2855
84348 [질문] 이키모노 가카리 노래 잘아시는분 [2] 처음이란2313 16/06/08 2313
84347 [질문] 자유게시판 댓글에 사진 올리기 가능 여부 [2] 삭제됨2303 16/06/08 2303
84346 [질문] 동물중 가족끼리 짝짓기을 하는 경우가 있나요? [10] 당신은누구십니까3171 16/06/08 3171
84345 [질문] [PC] 무선랜카드로 인터넷 사용하는데 인터넷 자동접속 방법 좀... [1] 본좌2146 16/06/08 2146
84344 [질문] [해축] 리버풀의 이적시장이 궁금합니다. [13] 별이지는언덕2344 16/06/08 2344
84343 [질문] 데이터 통신관련 질문입니다! Patrick Jane1545 16/06/08 1545
84342 [질문] [LOL] 넥슨 아레나 가보신분들께 궁금한게 있습니다 [4] SkinnerRules2920 16/06/08 2920
84341 [질문] 수면유도제를 많이 먹고 있는데.. [11] 아니아니4792 16/06/08 4792
84338 [질문] 이번주 상견례합니다. [7] 굿리치[alt]3243 16/06/07 3243
84337 [질문] 40대 남성분 넥타이 무슨 모양이 좋나요? [4] 2322 16/06/07 2322
84335 [질문] 뮤텍스 & 세마포어에 대해서 [6] iMac2169 16/06/07 2169
목록 이전 다음
댓글

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