name="google_ads_frame" marginwidth="0" marginheight="0" src="http://pagead2.googlesyndication.com/pagead/ads?client=ca-pub-5572165936844014&dt=1194442938015&lmt=1194190197&format=336x280_as&output=html&correlator=1194442937843&url=file%3A%2F%2F%2FC%3A%2FDocuments%2520and%2520Settings%2Flhh1%2F%E6%A1%8C%E9%9D%A2%2FCLanguage.htm&color_bg=FFFFFF&color_text=000000&color_link=000000&color_url=FFFFFF&color_border=FFFFFF&ad_type=text&ga_vid=583001034.1194442938&ga_sid=1194442938&ga_hid=1942779085&flash=9&u_h=768&u_w=1024&u_ah=740&u_aw=1024&u_cd=32&u_tz=480&u_java=true" frameborder="0" width="336" scrolling="no" height="280" allowtransparency="allowtransparency"> #include <genstub.cpp>
// Add these menu options.
#define IDM_READ 201
#define IDM_WRITE 202
// Windows message procedure.
LRESULT CALLBACK WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
static HANDLE hSemRead = 0; // Handle of the read semaphore.
static HANDLE hEventWrite = 0; // Handle of the write event.
switch (uMsg)
{
case WM_CREATE: // Make the two synchornization objects.
{
hSemRead = CreateSemaphore( NULL, 10, 10 "READ SEMAPHORE" );
hEventWrite = CreateEvent( NULL, TRUE, TRUE, "WRITE EVENT" );
return DefWindowProc( hWnd, uMsg, wParam, lParam );
}
break;
case WM_DESTROY: // Close the synchonization objects.
if ( hSemRead )
CloseHandle( hSemRead );
if ( hEventWrite )
CloseHandle( hEventWrite );
PostQuitMessage( 0 );
break;
case WM_COMMAND: // Process menu items
switch ( LOWORD( wParam ) )
{
case IDM_READ:
hSemRead = OpenSemaphore( SEMAPHORE_ALL_ACCESS, FALSE,
"Read Semaphore" );
hEventWrite = OpenEvent( SYNCHRONIZE, FALSE, "Write Event" );
SetWindowText( hWnd, "Waiting for all Writes to Finish" );
// Check that write manual reset event is signaled.
WaitForSingleObject( hEventWrite, INFINITE );
// Wait for semaphore.
WaitForSingleObject( hSemRead, INFINITE );
// Do the read.
SetWindowText( hWnd, "Reading" );
Sleep( 5000 ); // Sleep instead to dramatize contention.
// Release semaphore.
ReleaseSemaphore( hSemRead, 1, NULL );
SetWindowText( hWnd, "Done Reading" );
CloseHandle( hSemRead );
CloseHandle( hEventWrite );
break;
case IDM_WRITE:
{
DWORD dwSemaphoreCount = 0;
hSemRead = OpenSemaphore( SEMAPHORE_ALL_ACCESS, FALSE,
"Read Semaphore" );
hEventWrite = OpenEvent( SYNCHRONIZE, FALSE, "Write Event" );
// Wait for manual reset event object: it becomes non-signaled.
SetWindowText( hWnd, "Waiting for Write Event" );
WaitForSingleObject( hEventWrite, INFINITE );
ResetEvent( hEventWrite );
SetWindowText( hWnd, "Waiting for All Reads to Finish" );
// Get semaphore, Release semaphore until its count is maximum.
while ( dwSemaphoreCount!=SEMAPHORE_MAX_COUNT )
{
WaitForSingleObject( hSemRead, INFINITE );
ReleaseSemaphore( hSemRead, 1, &dwSemaphoreCount );
dwSemaphoreCount++;
}
SetWindowText( hWnd, "Writing" );
// Do the write.
Sleep( 10000 ); // Sleep instead to dramatize contention.
SetWindowText( hWnd, "Done Writing" );
// SetEvent: it becomes signaled.
SetEvent( hEventWrite );
CloseHandle( hSemRead );
CloseHandle( hEventWrite );
}
break;
case IDM_EXIT:
DestroyWindow( hWnd );
break;
}
break;
default:
return DefWindowProc( hWnd, uMsg, wParam, lParam );
}
return NULL;
}