<div><br><br><font size="1">Hello Mathew<br><br>Below I m attaching my simple code using ACE_RW_Process_Mutex and its output.<br><br> <br><br>Description of the problem--<br><br>I also tried it using ACE_Process_Mutex by just replacing the <font style="BACKGROUND-COLOR: #33ccff">ACE_RW_Process_Mutex</font> in code by ACE_Process_Mutex .With ACE_Process_Mutex ,synchronization is proper and writer and reader are acquiring and releasing in correct order .(when writer is releasing, then only reader is acquiring and vice versa. The output for the same is in last of the mail).<br>
<br>BUT when using ACE_RW_Process_Mutex ,the writer and reader are not in sync.<br><br>If we see the output for this as mentioned below, writer has acquired the mutex at <br><br>88112592 millisec and released at 88114592 millisec i..e writer is working for 2 sec and has acquired mutex for 2 sec.<br>
<br><font style="BACKGROUND-COLOR: #ffff66">(writer acquired 1 at 88112592<br><br> writer released 1 at 88114592)<br></font><br>Now when we see the Reader, it has acquired the mutex at 88112872 millisec.<br>
<br><font style="BACKGROUND-COLOR: #33ff33">(Reader acquired 0 at 88112872<br><br>Reader released 0 at 88114872)<br></font><br>This should ideally not happen as mutex is still with the writer and it is relasing at 88114592 millisec.<br>
<br> int ACE_TMAIN (int argc, ACE_TCHAR *argv[])<br><br><br>{<br><br>int count =0;<br><br>float ltime=0;<br><br> <font style="BACKGROUND-COLOR: #33ccff">ACE_RW_Process_Mutex</font> m_RWMutex(ACE_TEXT("MyMutex"));<br>
<br> if (agrc == 1) // For server which is writing<br><br> {<br><br> while (1)<br><br> {<br><br> if (m_RWMutex.acquire_write() == 0)<br><br> {<br><br> ltime = ::GetTickCount(); //number of millisec since the system has started<br>
<br> ACE_OS::printf("Writer acquired...%d at: %f\n",count++,ltime);<br><br> ACE_OS::sleep(2);<br><br> ltime = ::GetTickCount();<br><br> ACE_OS::printf("Writer releasing... ...%d at: %f\n",count++,ltime);<br>
<br> m_RWMutex.release();<br><br> }<br><br> }<br><br> }<br><br> else //For Client which is reading <br><br> {<br><br> while (1)<br><br> {<br><br>
if (m_RWMutex.acquire_read() == 0)<br><br> {<br><br> ltime = ::GetTickCount(); <br><br> ACE_OS::printf("Reader acquired... ...%d at: %f\n",count++,ltime);<br><br>
ACE_OS::sleep(2);<br><br> ltime = ::GetTickCount();<br><br> ACE_OS::printf("Reader releasing...%d at: %f\n",count++,ltime);<br><br> m_RWMutex.release();<br>
<br> }<br><br> }<br><br> }<br><br> return 0;<br><br>}</font></div>
<div><font size="1"></font> </div>
<div><font size="1">OUTPUT is like this(WITH ACE_RW_Process_Mutex):<br> <br><br><br>Writer count TimeStamp(in millisec) <br><br><br>writer acquired 0 at 88110592 <br><br>writer released 0 at 88112592<br>
<br><font style="BACKGROUND-COLOR: #ffff00">writer acquired 1 at 88112592<br><br>writer released 1 at 88114592<br></font><br>writer acquired 2 at 88114592<br><br>writer released 2 at 88116592<br>
<br>writer acquired 3 at 88116592<br><br>writer released 3 at 88118592<br><br> <br><br>Reader<br><br><font style="BACKGROUND-COLOR: #33ff33">Reader acquired 0 at 88112872<br><br>Reader released 0 at 88114872<br>
</font><br>Reader acquired 1 at 88114872<br><br>Reader released 1 at 88116872<br><br>Reader acquired 2 at 88116872<br><br>Reader released 2 at 88118872<br><br>Reader acquired 3 at 88118872<br>
<br> <br><br> <br><br>OUTPUT is like this (WITH ACE_Process_Mutex):<br><br> <br><br>Writer count TimeStamp(in millisec)<br><br> <br><br><font style="BACKGROUND-COLOR: #ffff00">writer acquired 0 at 88560984<br>
<br>writer released 0 at 88562984<br><br></font>writer acquired 1 at 88562984<br><br>writer released 1 at 88564984<br><br>writer acquired 2 at 88566984<br><br>writer released 2 at 88568984<br>
<br>writer acquired 3 at 88570984<br><br>writer released 3 at 88572984<br><br> <br><br>Reader<br><br><font style="BACKGROUND-COLOR: #33ff33">Reader acquired 0 at 88564984<br><br>Reader released 0 at 88566984<br>
</font><br>Reader acquired 1 at 88568984<br><br>Reader released 1 at 88570984<br><br>Reader acquired 2 at 88572984<br><br>Reader released 2 at 88574984<br><br>Reader acquired 3 at 88576984<br>
<br>Reader released 3 at 88578984<br><br> <br><br>Thanks<br><br>Kul<br><br><br><br> <br><br>On 3/3/08, Matthew Gillen <<a href="mailto:mgillen@bbn.com">mgillen@bbn.com</a>> wrote: <br><br>kul gupta wrote:<br>
> After having a look into ACE_ROOT/examples/Threads ,I implemented the<br>> following code using ACE_RW_Process_Mutex. and run in both Windows and<br>> linux5.0. But in both the cases the synchronization is not happening .<br>
<br>It would help if were more specific about what actually /is/ happening. Do<br>you see the output messages in the wrong order? Do you never see some<br>output messages?<br><br>Matt<br><br> <br><br> </font></div>