| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 |
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
- <meta http-equiv="X-UA-Compatible" content="IE=9"/>
- <title>RakNet: DataStructures::SingleProducerConsumer< SingleProducerConsumerType > Class Template Reference</title>
- <link href="tabs.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="jquery.js"></script>
- <script type="text/javascript" src="dynsections.js"></script>
- <link href="doxygen.css" rel="stylesheet" type="text/css" />
- </head>
- <body>
- <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
- <div id="titlearea">
- <table cellspacing="0" cellpadding="0">
- <tbody>
- <tr style="height: 56px;">
- <td style="padding-left: 0.5em;">
- <div id="projectname">RakNet
-  <span id="projectnumber">4.0</span>
- </div>
- </td>
- </tr>
- </tbody>
- </table>
- </div>
- <!-- end header part -->
- <!-- Generated by Doxygen 1.8.2 -->
- <div id="navrow1" class="tabs">
- <ul class="tablist">
- <li><a href="index.html"><span>Main Page</span></a></li>
- <li><a href="pages.html"><span>Related Pages</span></a></li>
- <li><a href="modules.html"><span>Modules</span></a></li>
- <li><a href="namespaces.html"><span>Namespaces</span></a></li>
- <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
- <li><a href="files.html"><span>Files</span></a></li>
- </ul>
- </div>
- <div id="navrow2" class="tabs2">
- <ul class="tablist">
- <li><a href="annotated.html"><span>Class List</span></a></li>
- <li><a href="classes.html"><span>Class Index</span></a></li>
- <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li>
- <li><a href="functions.html"><span>Class Members</span></a></li>
- </ul>
- </div>
- <div id="nav-path" class="navpath">
- <ul>
- <li class="navelem"><a class="el" href="namespaceDataStructures.html">DataStructures</a></li><li class="navelem"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">SingleProducerConsumer</a></li> </ul>
- </div>
- </div><!-- top -->
- <div class="header">
- <div class="summary">
- <a href="#pub-methods">Public Member Functions</a> |
- <a href="classDataStructures_1_1SingleProducerConsumer-members.html">List of all members</a> </div>
- <div class="headertitle">
- <div class="title">DataStructures::SingleProducerConsumer< SingleProducerConsumerType > Class Template Reference</div> </div>
- </div><!--header-->
- <div class="contents">
- <p>A single producer consumer implementation without critical sections.
- <a href="classDataStructures_1_1SingleProducerConsumer.html#details">More...</a></p>
- <p><code>#include <SingleProducerConsumer.h></code></p>
- <table class="memberdecls">
- <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
- Public Member Functions</h2></td></tr>
- <tr class="memitem:a875f6c2177c1ab29106472162b75c038"><td class="memItemLeft" align="right" valign="top">SingleProducerConsumerType * </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a875f6c2177c1ab29106472162b75c038">WriteLock</a> (void)</td></tr>
- <tr class="separator:a875f6c2177c1ab29106472162b75c038"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:adde3995822744b048b9e1df7a8bb02ff"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#adde3995822744b048b9e1df7a8bb02ff">CancelWriteLock</a> (SingleProducerConsumerType *cancelToLocation)</td></tr>
- <tr class="separator:adde3995822744b048b9e1df7a8bb02ff"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a2c5554a0297476b8f69e39b2721e1e23"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a2c5554a0297476b8f69e39b2721e1e23"></a>
- void </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a2c5554a0297476b8f69e39b2721e1e23">WriteUnlock</a> (void)</td></tr>
- <tr class="memdesc:a2c5554a0297476b8f69e39b2721e1e23"><td class="mdescLeft"> </td><td class="mdescRight">Call when you are done writing to a block of memory returned by <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a875f6c2177c1ab29106472162b75c038">WriteLock()</a> <br/></td></tr>
- <tr class="separator:a2c5554a0297476b8f69e39b2721e1e23"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a114026663fff4b0b5dac65f7b6b742c8"><td class="memItemLeft" align="right" valign="top">SingleProducerConsumerType * </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a114026663fff4b0b5dac65f7b6b742c8">ReadLock</a> (void)</td></tr>
- <tr class="separator:a114026663fff4b0b5dac65f7b6b742c8"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:aa08c579304d9a91f96a4e285324864eb"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa08c579304d9a91f96a4e285324864eb"></a>
- void </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#aa08c579304d9a91f96a4e285324864eb">CancelReadLock</a> (SingleProducerConsumerType *cancelToLocation)</td></tr>
- <tr class="memdesc:aa08c579304d9a91f96a4e285324864eb"><td class="mdescLeft"> </td><td class="mdescRight">param[in] Which <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a114026663fff4b0b5dac65f7b6b742c8">ReadLock()</a> to cancel. <br/></td></tr>
- <tr class="separator:aa08c579304d9a91f96a4e285324864eb"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:ab0440d6f877601c03b75deb1edbc94f6"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#ab0440d6f877601c03b75deb1edbc94f6">ReadUnlock</a> (void)</td></tr>
- <tr class="separator:ab0440d6f877601c03b75deb1edbc94f6"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a78853698d03871f26074d1b13a2772a8"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a78853698d03871f26074d1b13a2772a8"></a>
- void </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a78853698d03871f26074d1b13a2772a8">Clear</a> (void)</td></tr>
- <tr class="memdesc:a78853698d03871f26074d1b13a2772a8"><td class="mdescLeft"> </td><td class="mdescRight">Clear is not thread-safe and none of the lock or unlock functions should be called while it is running. <br/></td></tr>
- <tr class="separator:a78853698d03871f26074d1b13a2772a8"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:a4109a63f86171ccd3461082108f6febf"><td class="memItemLeft" align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a4109a63f86171ccd3461082108f6febf">Size</a> (void) const </td></tr>
- <tr class="separator:a4109a63f86171ccd3461082108f6febf"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:ab2d92e6bb0d68b8a1974cfd9eac90ed8"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#ab2d92e6bb0d68b8a1974cfd9eac90ed8">CheckReadUnlockOrder</a> (const SingleProducerConsumerType *data) const </td></tr>
- <tr class="separator:ab2d92e6bb0d68b8a1974cfd9eac90ed8"><td class="memSeparator" colspan="2"> </td></tr>
- <tr class="memitem:ad96259b75b794e8451ec29a40018f19d"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#ad96259b75b794e8451ec29a40018f19d">ReadIsLocked</a> (void) const </td></tr>
- <tr class="separator:ad96259b75b794e8451ec29a40018f19d"><td class="memSeparator" colspan="2"> </td></tr>
- </table>
- <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
- <div class="textblock"><h3>template<class SingleProducerConsumerType><br/>
- class DataStructures::SingleProducerConsumer< SingleProducerConsumerType ></h3>
- <p>A single producer consumer implementation without critical sections. </p>
- </div><h2 class="groupheader">Member Function Documentation</h2>
- <a class="anchor" id="adde3995822744b048b9e1df7a8bb02ff"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType> </div>
- <table class="memname">
- <tr>
- <td class="memname">void <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::CancelWriteLock </td>
- <td>(</td>
- <td class="paramtype">SingleProducerConsumerType * </td>
- <td class="paramname"><em>cancelToLocation</em></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Call if you don't want to write to a block of data from <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a875f6c2177c1ab29106472162b75c038">WriteLock()</a> after all. Cancelling locks cancels all locks back up to the data passed. So if you lock twice and cancel using the first lock, the second lock is ignored </p>
- <dl class="params"><dt>Parameters</dt><dd>
- <table class="params">
- <tr><td class="paramdir">[in]</td><td class="paramname">cancelToLocation</td><td>Which <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a875f6c2177c1ab29106472162b75c038">WriteLock()</a> to cancel. </td></tr>
- </table>
- </dd>
- </dl>
- </div>
- </div>
- <a class="anchor" id="ab2d92e6bb0d68b8a1974cfd9eac90ed8"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType> </div>
- <table class="memname">
- <tr>
- <td class="memname">bool <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::CheckReadUnlockOrder </td>
- <td>(</td>
- <td class="paramtype">const SingleProducerConsumerType * </td>
- <td class="paramname"><em>data</em></td><td>)</td>
- <td> const</td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Make sure that the pointer we done reading for the call to ReadUnlock is the right pointer. param[in] A previous pointer returned by <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html#a114026663fff4b0b5dac65f7b6b742c8">ReadLock()</a> </p>
- </div>
- </div>
- <a class="anchor" id="ad96259b75b794e8451ec29a40018f19d"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType > </div>
- <table class="memname">
- <tr>
- <td class="memname">bool <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::ReadIsLocked </td>
- <td>(</td>
- <td class="paramtype">void </td>
- <td class="paramname"></td><td>)</td>
- <td> const</td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Returns if ReadUnlock was called before ReadLock </p>
- <dl class="section return"><dt>Returns</dt><dd>If the read is locked </dd></dl>
- </div>
- </div>
- <a class="anchor" id="a114026663fff4b0b5dac65f7b6b742c8"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType > </div>
- <table class="memname">
- <tr>
- <td class="memname">SingleProducerConsumerType * <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::ReadLock </td>
- <td>(</td>
- <td class="paramtype">void </td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>ReadLock must be immediately followed by ReadUnlock. These two functions must be called in the same thread. </p>
- <dl class="retval"><dt>Return values</dt><dd>
- <table class="retval">
- <tr><td class="paramname">0</td><td>No data is availble to read </td></tr>
- <tr><td class="paramname">Non-zero</td><td>The data previously written to, in another thread, by WriteLock followed by WriteUnlock. </td></tr>
- </table>
- </dd>
- </dl>
- </div>
- </div>
- <a class="anchor" id="ab0440d6f877601c03b75deb1edbc94f6"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType > </div>
- <table class="memname">
- <tr>
- <td class="memname">void <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::ReadUnlock </td>
- <td>(</td>
- <td class="paramtype">void </td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>Signals that we are done reading the the data from the least recent call of ReadLock. At this point that pointer is no longer valid, and should no longer be read. </p>
- </div>
- </div>
- <a class="anchor" id="a4109a63f86171ccd3461082108f6febf"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType > </div>
- <table class="memname">
- <tr>
- <td class="memname">int <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::Size </td>
- <td>(</td>
- <td class="paramtype">void </td>
- <td class="paramname"></td><td>)</td>
- <td> const</td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>This function will estimate how many elements are waiting to be read. It's threadsafe enough that the value returned is stable, but not threadsafe enough to give accurate results. </p>
- <dl class="section return"><dt>Returns</dt><dd>An ESTIMATE of how many data elements are waiting to be read </dd></dl>
- </div>
- </div>
- <a class="anchor" id="a875f6c2177c1ab29106472162b75c038"></a>
- <div class="memitem">
- <div class="memproto">
- <div class="memtemplate">
- template<class SingleProducerConsumerType > </div>
- <table class="memname">
- <tr>
- <td class="memname">SingleProducerConsumerType * <a class="el" href="classDataStructures_1_1SingleProducerConsumer.html">DataStructures::SingleProducerConsumer</a>< SingleProducerConsumerType >::WriteLock </td>
- <td>(</td>
- <td class="paramtype">void </td>
- <td class="paramname"></td><td>)</td>
- <td></td>
- </tr>
- </table>
- </div><div class="memdoc">
- <p>WriteLock must be immediately followed by WriteUnlock. These two functions must be called in the same thread. </p>
- <dl class="section return"><dt>Returns</dt><dd>A pointer to a block of data you can write to. </dd></dl>
- </div>
- </div>
- <hr/>The documentation for this class was generated from the following file:<ul>
- <li>D:/temp/RakNet_PC/Source/<a class="el" href="SingleProducerConsumer_8h.html">SingleProducerConsumer.h</a></li>
- </ul>
- </div><!-- contents -->
- <!-- start footer part -->
- <hr class="footer"/><address class="footer"><small>
- Generated on Mon Jun 2 2014 20:10:28 for RakNet by  <a href="http://www.doxygen.org/index.html">
- <img class="footer" src="doxygen.png" alt="doxygen"/>
- </a> 1.8.2
- </small></address>
- </body>
- </html>
|