You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

221 lines
15 KiB

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  2. <html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
  3. <title>tbb::interface5::reader_writer_lock Class Reference</title>
  4. <link href="doxygen.css" rel="stylesheet" type="text/css">
  5. <link href="tabs.css" rel="stylesheet" type="text/css">
  6. </head><body>
  7. <!-- Generated by Doxygen 1.4.7 -->
  8. <div class="tabs">
  9. <ul>
  10. <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
  11. <li><a href="modules.html"><span>Modules</span></a></li>
  12. <li><a href="namespaces.html"><span>Namespaces</span></a></li>
  13. <li id="current"><a href="annotated.html"><span>Classes</span></a></li>
  14. <li><a href="files.html"><span>Files</span></a></li>
  15. <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
  16. </ul></div>
  17. <div class="tabs">
  18. <ul>
  19. <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
  20. <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
  21. <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
  22. </ul></div>
  23. <div class="nav">
  24. <a class="el" href="a00428.html">tbb</a>::<b>interface5</b>::<a class="el" href="a00330.html">reader_writer_lock</a></div>
  25. <h1>tbb::interface5::reader_writer_lock Class Reference<br>
  26. <small>
  27. [<a class="el" href="a00444.html">Synchronization</a>]</small>
  28. </h1><!-- doxytag: class="tbb::interface5::reader_writer_lock" -->Writer-preference reader-writer lock with local-only spinning on readers.
  29. <a href="#_details">More...</a>
  30. <p>
  31. <code>#include &lt;reader_writer_lock.h&gt;</code>
  32. <p>
  33. <a href="a00116.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
  34. <tr><td></td></tr>
  35. <tr><td colspan="2"><br><h2>Public Types</h2></td></tr>
  36. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="6f921f0d7c1812ceb5674418c8b6ccaf005142e2b9af377a8d33c6604d858862"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::waiting_nonblocking" ref="6f921f0d7c1812ceb5674418c8b6ccaf005142e2b9af377a8d33c6604d858862" args="" -->
  37. &nbsp;</td><td class="memItemRight" valign="bottom"><b>waiting_nonblocking</b></td></tr>
  38. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="6f921f0d7c1812ceb5674418c8b6ccaf18bcc9aae8f056c34fb61bb7fc39b432"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::waiting" ref="6f921f0d7c1812ceb5674418c8b6ccaf18bcc9aae8f056c34fb61bb7fc39b432" args="" -->
  39. &nbsp;</td><td class="memItemRight" valign="bottom"><b>waiting</b></td></tr>
  40. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="6f921f0d7c1812ceb5674418c8b6ccaf423c082d5cdc9bb12d0eeadcae56adb5"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::active" ref="6f921f0d7c1812ceb5674418c8b6ccaf423c082d5cdc9bb12d0eeadcae56adb5" args="" -->
  41. &nbsp;</td><td class="memItemRight" valign="bottom"><b>active</b></td></tr>
  42. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="6f921f0d7c1812ceb5674418c8b6ccafa9a5b17bdfb0a6d59b3cd58fecbd9610"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::invalid" ref="6f921f0d7c1812ceb5674418c8b6ccafa9a5b17bdfb0a6d59b3cd58fecbd9610" args="" -->
  43. &nbsp;</td><td class="memItemRight" valign="bottom"><b>invalid</b></td></tr>
  44. <tr><td class="memItemLeft" nowrap align="right" valign="top">enum &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#6f921f0d7c1812ceb5674418c8b6ccaf">status_t</a> { <b>waiting_nonblocking</b>,
  45. <b>waiting</b>,
  46. <b>active</b>,
  47. <b>invalid</b>
  48. }</td></tr>
  49. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Status type for nodes associated with lock instances. <a href="a00330.html#6f921f0d7c1812ceb5674418c8b6ccaf">More...</a><br></td></tr>
  50. <tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
  51. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="c1431c4293e777efd9aab9a95c2a46e1"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::reader_writer_lock" ref="c1431c4293e777efd9aab9a95c2a46e1" args="()" -->
  52. &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#c1431c4293e777efd9aab9a95c2a46e1">reader_writer_lock</a> ()</td></tr>
  53. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Constructs a new <a class="el" href="a00330.html">reader_writer_lock</a>. <br></td></tr>
  54. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="5135f64f7b7339017f33d956445edbee"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::~reader_writer_lock" ref="5135f64f7b7339017f33d956445edbee" args="()" -->
  55. &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#5135f64f7b7339017f33d956445edbee">~reader_writer_lock</a> ()</td></tr>
  56. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Destructs a <a class="el" href="a00330.html">reader_writer_lock</a> object. <br></td></tr>
  57. <tr><td class="memItemLeft" nowrap align="right" valign="top">void __TBB_EXPORTED_METHOD&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#2653d1a2d560059a51219a8ceab3ade9">lock</a> ()</td></tr>
  58. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Acquires the <a class="el" href="a00330.html">reader_writer_lock</a> for write. <a href="#2653d1a2d560059a51219a8ceab3ade9"></a><br></td></tr>
  59. <tr><td class="memItemLeft" nowrap align="right" valign="top">bool __TBB_EXPORTED_METHOD&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#721eb173e154ab38292273e9266a9b07">try_lock</a> ()</td></tr>
  60. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Tries to acquire the <a class="el" href="a00330.html">reader_writer_lock</a> for write. <a href="#721eb173e154ab38292273e9266a9b07"></a><br></td></tr>
  61. <tr><td class="memItemLeft" nowrap align="right" valign="top">void __TBB_EXPORTED_METHOD&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#d9d16a24d9f6c3dada73c6b9ff214f5b">lock_read</a> ()</td></tr>
  62. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Acquires the <a class="el" href="a00330.html">reader_writer_lock</a> for read. <a href="#d9d16a24d9f6c3dada73c6b9ff214f5b"></a><br></td></tr>
  63. <tr><td class="memItemLeft" nowrap align="right" valign="top">bool __TBB_EXPORTED_METHOD&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#595fb23952e3b89426b1f7938dea9b11">try_lock_read</a> ()</td></tr>
  64. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Tries to acquire the <a class="el" href="a00330.html">reader_writer_lock</a> for read. <a href="#595fb23952e3b89426b1f7938dea9b11"></a><br></td></tr>
  65. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="5113b32689305599b2c36b5831547704"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::unlock" ref="5113b32689305599b2c36b5831547704" args="()" -->
  66. void __TBB_EXPORTED_METHOD&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00330.html#5113b32689305599b2c36b5831547704">unlock</a> ()</td></tr>
  67. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Releases the <a class="el" href="a00330.html">reader_writer_lock</a>. <br></td></tr>
  68. <tr><td colspan="2"><br><h2>Friends</h2></td></tr>
  69. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="a36f15b770a1bb0b56e33d7fa75ebd1a"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::scoped_lock" ref="a36f15b770a1bb0b56e33d7fa75ebd1a" args="" -->
  70. class&nbsp;</td><td class="memItemRight" valign="bottom"><b>scoped_lock</b></td></tr>
  71. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="680274059774b9188889d34986314f81"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::scoped_lock_read" ref="680274059774b9188889d34986314f81" args="" -->
  72. class&nbsp;</td><td class="memItemRight" valign="bottom"><b>scoped_lock_read</b></td></tr>
  73. <tr><td colspan="2"><br><h2>Classes</h2></td></tr>
  74. <tr><td class="memItemLeft" nowrap align="right" valign="top">class &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00331.html">scoped_lock</a></td></tr>
  75. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The scoped lock pattern for write locks. <a href="a00331.html#_details">More...</a><br></td></tr>
  76. <tr><td class="memItemLeft" nowrap align="right" valign="top">class &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00332.html">scoped_lock_read</a></td></tr>
  77. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The scoped lock pattern for read locks. <a href="a00332.html#_details">More...</a><br></td></tr>
  78. </table>
  79. <hr><a name="_details"></a><h2>Detailed Description</h2>
  80. Writer-preference reader-writer lock with local-only spinning on readers.
  81. <p>
  82. Loosely adapted from Mellor-Crummey and Scott pseudocode at <a href="http://www.cs.rochester.edu/research/synchronization/pseudocode/rw.html#s_wp">http://www.cs.rochester.edu/research/synchronization/pseudocode/rw.html#s_wp</a>
  83. <p>
  84. <hr><h2>Member Enumeration Documentation</h2>
  85. <a class="anchor" name="6f921f0d7c1812ceb5674418c8b6ccaf"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::status_t" ref="6f921f0d7c1812ceb5674418c8b6ccaf" args="" -->
  86. <div class="memitem">
  87. <div class="memproto">
  88. <table class="memname">
  89. <tr>
  90. <td class="memname">enum <a class="el" href="a00330.html#6f921f0d7c1812ceb5674418c8b6ccaf">tbb::interface5::reader_writer_lock::status_t</a> </td>
  91. </tr>
  92. </table>
  93. </div>
  94. <div class="memdoc">
  95. <p>
  96. Status type for nodes associated with lock instances.
  97. <p>
  98. waiting_nonblocking: the wait state for nonblocking lock instances; for writes, these transition straight to active states; for reads, these are unused.<p>
  99. waiting: the start and spin state for all lock instances; these will transition to active state when appropriate. Non-blocking write locks transition from this state to waiting_nonblocking immediately.<p>
  100. active: the active state means that the lock instance holds the lock; it will transition to invalid state during node deletion<p>
  101. invalid: the end state for all nodes; this is set in the destructor so if we encounter this state, we are looking at memory that has already been freed<p>
  102. The state diagrams below describe the status transitions. Single arrows indicate that the thread that owns the node is responsible for the transition; double arrows indicate that any thread could make the transition.<p>
  103. State diagram for <a class="el" href="a00331.html">scoped_lock</a> status:<p>
  104. waiting ----------&gt; waiting_nonblocking | _____________/ | V V V active -----------------&gt; invalid<p>
  105. State diagram for <a class="el" href="a00332.html">scoped_lock_read</a> status:<p>
  106. waiting | V active -----------------&gt;invalid
  107. </div>
  108. </div><p>
  109. <hr><h2>Member Function Documentation</h2>
  110. <a class="anchor" name="2653d1a2d560059a51219a8ceab3ade9"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::lock" ref="2653d1a2d560059a51219a8ceab3ade9" args="()" -->
  111. <div class="memitem">
  112. <div class="memproto">
  113. <table class="memname">
  114. <tr>
  115. <td class="memname">void __TBB_EXPORTED_METHOD tbb::interface5::reader_writer_lock::lock </td>
  116. <td>(</td>
  117. <td class="paramname"> </td>
  118. <td>&nbsp;)&nbsp;</td>
  119. <td width="100%"></td>
  120. </tr>
  121. </table>
  122. </div>
  123. <div class="memdoc">
  124. <p>
  125. Acquires the <a class="el" href="a00330.html">reader_writer_lock</a> for write.
  126. <p>
  127. If the lock is currently held in write mode by another context, the writer will block by spinning on a local variable. Exceptions thrown: <a class="el" href="a00302.html">improper_lock</a> The context tries to acquire a <a class="el" href="a00330.html">reader_writer_lock</a> that it already has write ownership of.
  128. </div>
  129. </div><p>
  130. <a class="anchor" name="d9d16a24d9f6c3dada73c6b9ff214f5b"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::lock_read" ref="d9d16a24d9f6c3dada73c6b9ff214f5b" args="()" -->
  131. <div class="memitem">
  132. <div class="memproto">
  133. <table class="memname">
  134. <tr>
  135. <td class="memname">void __TBB_EXPORTED_METHOD tbb::interface5::reader_writer_lock::lock_read </td>
  136. <td>(</td>
  137. <td class="paramname"> </td>
  138. <td>&nbsp;)&nbsp;</td>
  139. <td width="100%"></td>
  140. </tr>
  141. </table>
  142. </div>
  143. <div class="memdoc">
  144. <p>
  145. Acquires the <a class="el" href="a00330.html">reader_writer_lock</a> for read.
  146. <p>
  147. If the lock is currently held by a writer, this reader will block and wait until the writers are done. Exceptions thrown: <a class="el" href="a00302.html">improper_lock</a> The context tries to acquire a <a class="el" href="a00330.html">reader_writer_lock</a> that it already has write ownership of.
  148. </div>
  149. </div><p>
  150. <a class="anchor" name="721eb173e154ab38292273e9266a9b07"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::try_lock" ref="721eb173e154ab38292273e9266a9b07" args="()" -->
  151. <div class="memitem">
  152. <div class="memproto">
  153. <table class="memname">
  154. <tr>
  155. <td class="memname">bool __TBB_EXPORTED_METHOD tbb::interface5::reader_writer_lock::try_lock </td>
  156. <td>(</td>
  157. <td class="paramname"> </td>
  158. <td>&nbsp;)&nbsp;</td>
  159. <td width="100%"></td>
  160. </tr>
  161. </table>
  162. </div>
  163. <div class="memdoc">
  164. <p>
  165. Tries to acquire the <a class="el" href="a00330.html">reader_writer_lock</a> for write.
  166. <p>
  167. This function does not block. Return Value: True or false, depending on whether the lock is acquired or not. If the lock is already held by this acquiring context, <a class="el" href="a00330.html#721eb173e154ab38292273e9266a9b07">try_lock()</a> returns false.
  168. </div>
  169. </div><p>
  170. <a class="anchor" name="595fb23952e3b89426b1f7938dea9b11"></a><!-- doxytag: member="tbb::interface5::reader_writer_lock::try_lock_read" ref="595fb23952e3b89426b1f7938dea9b11" args="()" -->
  171. <div class="memitem">
  172. <div class="memproto">
  173. <table class="memname">
  174. <tr>
  175. <td class="memname">bool __TBB_EXPORTED_METHOD tbb::interface5::reader_writer_lock::try_lock_read </td>
  176. <td>(</td>
  177. <td class="paramname"> </td>
  178. <td>&nbsp;)&nbsp;</td>
  179. <td width="100%"></td>
  180. </tr>
  181. </table>
  182. </div>
  183. <div class="memdoc">
  184. <p>
  185. Tries to acquire the <a class="el" href="a00330.html">reader_writer_lock</a> for read.
  186. <p>
  187. This function does not block. Return Value: True or false, depending on whether the lock is acquired or not.
  188. </div>
  189. </div><p>
  190. <hr>The documentation for this class was generated from the following file:<ul>
  191. <li>reader_writer_lock.h</ul>
  192. <hr>
  193. <p></p>
  194. Copyright &copy; 2005-2013 Intel Corporation. All Rights Reserved.
  195. <p></p>
  196. Intel, Pentium, Intel Xeon, Itanium, Intel XScale and VTune are
  197. registered trademarks or trademarks of Intel Corporation or its
  198. subsidiaries in the United States and other countries.
  199. <p></p>
  200. * Other names and brands may be claimed as the property of others.