로그인

검색

조회 수 1137 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄


#include <time.h>
#include <stdio.h>
#include <windows.h>
#include <queue> // STL의 큐
#define FULL 99

using namespace std;

queue <int> Q;  // 공유자원 - 모든 스레드가 공유한다.
HANDLE hMutex;  // 접근을 동기(동시 접근을 막는다)화 하기 위한 방법
HANDLE hSem1;  // Q에 있는 자원의 갯수를 나타낸다.
HANDLE hSem2;  // Q에 있는 자원의 갯수를 나타낸다.

DWORD WINAPI Produce(void* p)
{
static int n = 0;
while(1)
{
n = n+1;

// 아래 If문을 뮤텍스 밖에 둔 이유?
// 뮤텍스 구간(?)에서는 자원을 consume 쓰레드가 이용할 수 없는 기능으로 인해서이다.
// 우리가 원하는 것은 큐Size 체크 후 100 이상이면, 잠시 생산을 중지하고 consume 쓰레드에서...
if(Q.size() >= FULL )
{
// 큐가 100을 넘으면 세마포어(hSem2) 초기치 count 1(max, 1)에서 
// WaitFroSingleObject에서 count는 0으로 되고 2번째인자가 INFINITE이므로
// hSem2가 Signaled 될때가지 대기한다.
// (consume 쓰레드에서 ReleaseSemaphore(hSem2)를 해주면 다시 count는 1로 증가하고
//  signal이되어 대기모드에서 해제되어 다음으로 넘어가게 된다.
WaitForSingleObject(hSem2, INFINITE); 
}

// Q의 독점적인 접근 권한을 얻는다.
WaitForSingleObject(hMutex, INFINITE);
Q.push(n); // 생산
printf("Produce: %d  [ Q: %d ]n", n, Q.size());
// Q에 넣었으므로 세마포어 증가
LONG old;
ReleaseSemaphore(hSem1, 1, &old);  
ReleaseMutex(hMutex);

Sleep((rand() % 20) * 10); // 생산자 속도 빠르게... 0.2 ~ 2초간 대기

}

return 0;
}

DWORD WINAPI Consume(void *)
{
while(1)
{
int n;
LONG old, old2;

WaitForSingleObject(hSem1, INFINITE);
WaitForSingleObject(hMutex, INFINITE);
n = Q.front();    // Q의 제일 윗 요소 얻기
Q.pop();        // Q의 제일 윗 요소 제거 
printf("tttttConsume: %d  [ Q: %d ]n", n, Q.size());    
ReleaseSemaphore(hSem1, 1, &old);     
ReleaseMutex(hMutex);

// produce 쓰레드에서 hSem2이 Wait.. 상태이면 signal이 되게 해서 대기모드를 해제한다
// 아래는 큐가 100이 안넘어도 작동은 하지만 최대치가 1이므로 count는 증가하지 않는다.
// ( produce 쓰레드에서 100이 넘으면, wait하고 소비자에서 소비하게 하고 releasesemaphore를 해서
//   다시 produce 쓰레드를 wait를 해제한다. )
ReleaseSemaphore(hSem2, 1, &old2);

Sleep((rand() % 20) * 50); // 소비자 속도 느리게... 0.2 ~ 2초간 대기.
}

return 0;
}

void main()
{
hMutex = CreateMutex(0, 0, "ACCESS_GUARD");
hSem1 = CreateSemaphore(0, 0, 100, "Q_COUNT"); // 초기 0, 최대 100개의 세마포어
hSem2 = CreateSemaphore(0, 1, 1, "Q_FLG");     // 초기 1, 최대 1개의 세마포어

srand(time(0));
HANDLE h[2];

h[0] = CreateThread(0, 0, Produce, 0, 0, 0);
h[1] = CreateThread(0, 0, Consume, 0, 0, 0);

WaitForMultipleObjects(2, h, TRUE, INFINITE);
}

 

 

이걸로 메시지 큐를 구현할 수 있을지는 미지수

 

http://cafe.naver.com/cppmaster/866

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 5307
288 API/MFC __cdecl , __pascal, __stdcall MoA 2013.07.28 1268
287 C/C++ __FILE__ __LINE__ __FUNCTION__ 등 매크로 MoA 2014.01.02 1502
286 LLM [12월 1주] 떠오르는 '미스트랄 7B'...'라마 2' 이어 한국어 모델 세대교체 주도 OBG 2024.03.05 471
285 Python [GUI] Tkinter, wxPython MoA 2013.11.27 1541
284 Python [GUI] wxPython 기본 프로그램 file MoA 2013.11.30 1411
283 Python [GUI] wxPython에서 에러메시지 콘솔로 보는 법 MoA 2013.12.03 1325
282 Deeplearning [ifkakao] 추천 시스템: 맥락과 취향 사이 줄타 OBG 2024.01.10 376
281 Web [Javascript] 비동기, Promise, async, await 확실하게 이해하기 OBG 2022.05.27 396
280 Library [OpenCV] 얼굴 인식 예제 file MoA 2012.10.14 1857
279 Tool/etc [S/W 공학] 월-인원(man-month), LOC MoA 2013.09.23 1355
278 LLM [VESSL AI] 뉴욕주민의 프로젝트플루토 — LLM, LLMOps를 활용한 금융 미디어의 혁신 OBG 2024.04.21 705
277 Python [게임 만들기] 강좌 진행 예정 2 MoA 2014.04.26 2092
276 Python [농장게임 만들기] 1. Nubcake Farms 게임 소개 4 file OBG 2014.04.26 2310
275 Python [농장게임 만들기] 10. 상점을 추가하자 file MoA 2014.05.01 2986
274 Python [농장게임 만들기] 2. Nubcake Farms 클래스 분석 3 file OBG 2014.04.26 1397
273 Python [농장게임 만들기] 3. 배경을 그리자 6 file MoA 2014.04.28 2749
272 Python [농장게임 만들기] 4. 펜스를 그리자 5 file MoA 2014.04.30 1317
271 Python [농장게임 만들기] 5. 플레이어를 추가하자 1 file MoA 2014.04.30 1216
270 Python [농장게임 만들기] 6. 나머지 오브젝트를 그리자 1 file MoA 2014.05.01 1591
269 Python [농장게임 만들기] 7. 농부 행동 추가 1 file MoA 2014.05.01 1216
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15