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
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
86180 [질문] 하이마트 물건 구입후에 문제입니다 [1] 치매증상2686 16/07/09 2686
86179 [질문] 플스하려면 뭐사야하죠?? [2] Xavi2673 16/07/09 2673
86178 [질문] 기승전결 다 재밌는 애니메이션? [16] 프즈히4154 16/07/09 4154
86177 [질문] 요즘 커피만 마시면 설사가 나는데 방법이 없을가요? [8] 도깽이22326 16/07/09 22326
86176 [질문] 트루 디텍티브 같은 깔쌈한 미드 없을까요? [4] 토욜저녁축구와치맥캬5256 16/07/09 5256
86175 [질문] 고전오락실게임 질문드립니다 [1] crutine3169 16/07/09 3169
86174 [질문] 최신무협소설 중에서 볼만한 작품있나요? [9] 츠네모리 아카네11101 16/07/09 11101
86173 [질문] 인천공항 라운지 이용문의 [4] 어느새주말4242 16/07/09 4242
86172 [질문] 역대 고티 가장 운좋게?탄 1위와 가장 안타깝게미끄러진 2위는? [9] 선동가4192 16/07/09 4192
86171 [질문] [컴맹] 쓰던 하드 인식질문.. [1] 페이커센빠이3574 16/07/09 3574
86170 [질문] 주말부부.. 질문합니다 [7] Annnnnnn4341 16/07/09 4341
86169 [질문] SK데이터를 사람에게 살 수도 있나요?? [7] 테란완전정복3065 16/07/09 3065
86168 [질문] 기어핏2와 기어s2 사이에서 고민중입니다. [2] BBC특전대4876 16/07/09 4876
86167 [질문] 하체운동으로써 전력질주의 효과?(+손목 통증) [8] 물범6945 16/07/09 6945
86166 [질문] 오늘 첫알바인데 계산하는게 너무 어려워요. [6] Genius5515 16/07/09 5515
86165 [질문] 컴퓨터 질문드립니다(윈도우10 화면) [2] 삭제됨4618 16/07/09 4618
86164 [질문] 외국에서도 개라 부르면 욕이 되나요? [7] 마르키아르3953 16/07/09 3953
86163 [질문] 예비군 2차가 오늘인데 늦잠을 자버렸습니다 ㅜㅜ [18] 정공법16166 16/07/09 16166
86161 [질문] [오버워치] 사양 질문드립니다 [1] ...And justice2571 16/07/09 2571
86160 [질문] [히어로즈] 친구와 1:1을 하기로 했습니다. [16] Newbie3682 16/07/09 3682
86159 [질문] 현재 중고 가성비 좋은 그래픽카드 뭔가요 [4] 김여유4043 16/07/09 4043
86158 [질문] 그린라이트 여부 판단부탁드립니다 [9] 콩콩지4293 16/07/09 4293
86157 [질문] [히어로즈] 캐릭터 대사가 안나옵니다. [1] 파란만장3614 16/07/09 3614
목록 이전 다음
댓글

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