基于C++ Coroutines提案 ‘Stackless Resumable Functions’编写的协程库
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.

structresumef_1_1mutex__t.html 43KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.17"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>librf: resumef::mutex_t结构体 参考</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="search/searchdata.js"></script>
  14. <script type="text/javascript" src="search/search.js"></script>
  15. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  16. </head>
  17. <body>
  18. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  19. <div id="titlearea">
  20. <table cellspacing="0" cellpadding="0">
  21. <tbody>
  22. <tr style="height: 56px;">
  23. <td id="projectalign" style="padding-left: 0.5em;">
  24. <div id="projectname">librf
  25. </div>
  26. </td>
  27. </tr>
  28. </tbody>
  29. </table>
  30. </div>
  31. <!-- end header part -->
  32. <!-- 制作者 Doxygen 1.8.17 -->
  33. <script type="text/javascript">
  34. /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
  35. var searchBox = new SearchBox("searchBox", "search",false,'搜索');
  36. /* @license-end */
  37. </script>
  38. <script type="text/javascript" src="menudata.js"></script>
  39. <script type="text/javascript" src="menu.js"></script>
  40. <script type="text/javascript">
  41. /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
  42. $(function() {
  43. initMenu('',true,false,'search.php','搜索');
  44. $(document).ready(function() { init_search(); });
  45. });
  46. /* @license-end */</script>
  47. <div id="main-nav"></div>
  48. <!-- window showing the filter options -->
  49. <div id="MSearchSelectWindow"
  50. onmouseover="return searchBox.OnSearchSelectShow()"
  51. onmouseout="return searchBox.OnSearchSelectHide()"
  52. onkeydown="return searchBox.OnSearchSelectKey(event)">
  53. </div>
  54. <!-- iframe showing the search results (closed by default) -->
  55. <div id="MSearchResultsWindow">
  56. <iframe src="javascript:void(0)" frameborder="0"
  57. name="MSearchResults" id="MSearchResults">
  58. </iframe>
  59. </div>
  60. <div id="nav-path" class="navpath">
  61. <ul>
  62. <li class="navelem"><b>resumef</b></li><li class="navelem"><a class="el" href="structresumef_1_1mutex__t.html">mutex_t</a></li> </ul>
  63. </div>
  64. </div><!-- top -->
  65. <div class="header">
  66. <div class="summary">
  67. <a href="#pub-methods">Public 成员函数</a> &#124;
  68. <a href="#pub-static-methods">静态 Public 成员函数</a> &#124;
  69. <a href="structresumef_1_1mutex__t-members.html">所有成员列表</a> </div>
  70. <div class="headertitle">
  71. <div class="title">resumef::mutex_t结构体 参考</div> </div>
  72. </div><!--header-->
  73. <div class="contents">
  74. <p>支持递归的锁。
  75. <a href="structresumef_1_1mutex__t.html#details">更多...</a></p>
  76. <table class="memberdecls">
  77. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
  78. Public 成员函数</h2></td></tr>
  79. <tr class="memitem:a15c654948f47113fc92223a811d60090"><td class="memItemLeft" align="right" valign="top">awaiter&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a15c654948f47113fc92223a811d60090">lock</a> () const noexcept</td></tr>
  80. <tr class="memdesc:a15c654948f47113fc92223a811d60090"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中加锁,如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 <a href="structresumef_1_1mutex__t.html#a15c654948f47113fc92223a811d60090">更多...</a><br /></td></tr>
  81. <tr class="separator:a15c654948f47113fc92223a811d60090"><td class="memSeparator" colspan="2">&#160;</td></tr>
  82. <tr class="memitem:a9f086f150094d041b0c4372a8de504de"><td class="memItemLeft" align="right" valign="top">awaiter&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a9f086f150094d041b0c4372a8de504de">operator co_await</a> () const noexcept</td></tr>
  83. <tr class="memdesc:a9f086f150094d041b0c4372a8de504de"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中加锁。 <a href="structresumef_1_1mutex__t.html#a9f086f150094d041b0c4372a8de504de">更多...</a><br /></td></tr>
  84. <tr class="separator:a9f086f150094d041b0c4372a8de504de"><td class="memSeparator" colspan="2">&#160;</td></tr>
  85. <tr class="memitem:aad074e28785741eb1615d3126da6088a"><td class="memItemLeft" align="right" valign="top">manual_awaiter&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#aad074e28785741eb1615d3126da6088a">lock</a> (<a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a> manual_unlock_tag) const noexcept</td></tr>
  86. <tr class="memdesc:aad074e28785741eb1615d3126da6088a"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中加锁,如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 <a href="structresumef_1_1mutex__t.html#aad074e28785741eb1615d3126da6088a">更多...</a><br /></td></tr>
  87. <tr class="separator:aad074e28785741eb1615d3126da6088a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  88. <tr class="memitem:a2844d5df6562c153bc5b32d1720efb30"><td class="memItemLeft" align="right" valign="top">try_awaiter&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a2844d5df6562c153bc5b32d1720efb30">try_lock</a> () const noexcept</td></tr>
  89. <tr class="memdesc:a2844d5df6562c153bc5b32d1720efb30"><td class="mdescLeft">&#160;</td><td class="mdescRight">尝试在协程中加锁。此操作无论成功与否都会立即返回,不会有协程切换。 <a href="structresumef_1_1mutex__t.html#a2844d5df6562c153bc5b32d1720efb30">更多...</a><br /></td></tr>
  90. <tr class="separator:a2844d5df6562c153bc5b32d1720efb30"><td class="memSeparator" colspan="2">&#160;</td></tr>
  91. <tr class="memitem:a430ec9f4b9bb1c5711b6ba7ef3a1ad99"><td class="memItemLeft" align="right" valign="top">unlock_awaiter&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a430ec9f4b9bb1c5711b6ba7ef3a1ad99">unlock</a> () const noexcept</td></tr>
  92. <tr class="memdesc:a430ec9f4b9bb1c5711b6ba7ef3a1ad99"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中解锁。此操作立即返回,不会有协程切换。 <a href="structresumef_1_1mutex__t.html#a430ec9f4b9bb1c5711b6ba7ef3a1ad99">更多...</a><br /></td></tr>
  93. <tr class="separator:a430ec9f4b9bb1c5711b6ba7ef3a1ad99"><td class="memSeparator" colspan="2">&#160;</td></tr>
  94. <tr class="memitem:afca20661d92d6acac34b324cab774310"><td class="memTemplParams" colspan="2">template&lt;class _Rep , class _Period &gt; </td></tr>
  95. <tr class="memitem:afca20661d92d6acac34b324cab774310"><td class="memTemplItemLeft" align="right" valign="top">timeout_awaiter&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#afca20661d92d6acac34b324cab774310">try_lock_for</a> (const std::chrono::duration&lt; _Rep, _Period &gt; &amp;dt) const noexcept</td></tr>
  96. <tr class="memdesc:afca20661d92d6acac34b324cab774310"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中尝试加锁,直到超时。如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 <a href="structresumef_1_1mutex__t.html#afca20661d92d6acac34b324cab774310">更多...</a><br /></td></tr>
  97. <tr class="separator:afca20661d92d6acac34b324cab774310"><td class="memSeparator" colspan="2">&#160;</td></tr>
  98. <tr class="memitem:ada9a310ff364fa8b1ee78dc2f799a8a5"><td class="memTemplParams" colspan="2">template&lt;class _Rep , class _Period &gt; </td></tr>
  99. <tr class="memitem:ada9a310ff364fa8b1ee78dc2f799a8a5"><td class="memTemplItemLeft" align="right" valign="top">timeout_awaiter&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#ada9a310ff364fa8b1ee78dc2f799a8a5">try_lock_until</a> (const std::chrono::time_point&lt; _Rep, _Period &gt; &amp;tp) const noexcept</td></tr>
  100. <tr class="memdesc:ada9a310ff364fa8b1ee78dc2f799a8a5"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中尝试加锁,直到超时。如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 <a href="structresumef_1_1mutex__t.html#ada9a310ff364fa8b1ee78dc2f799a8a5">更多...</a><br /></td></tr>
  101. <tr class="separator:ada9a310ff364fa8b1ee78dc2f799a8a5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  102. <tr class="memitem:a3442f7c56bed34e086bd5bd41e4a9c5a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a3442f7c56bed34e086bd5bd41e4a9c5a">lock</a> (void *unique_address) const</td></tr>
  103. <tr class="memdesc:a3442f7c56bed34e086bd5bd41e4a9c5a"><td class="mdescLeft">&#160;</td><td class="mdescRight">在非协程中加锁。如果不能立即获得锁,则反复尝试,直到获得锁。故会阻塞当前协程 <a href="structresumef_1_1mutex__t.html#a3442f7c56bed34e086bd5bd41e4a9c5a">更多...</a><br /></td></tr>
  104. <tr class="separator:a3442f7c56bed34e086bd5bd41e4a9c5a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  105. <tr class="memitem:a1dd128870c1fdcc7261ef0fa63e12254"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a1dd128870c1fdcc7261ef0fa63e12254">try_lock</a> (void *unique_address) const</td></tr>
  106. <tr class="memdesc:a1dd128870c1fdcc7261ef0fa63e12254"><td class="mdescLeft">&#160;</td><td class="mdescRight">尝试在非协程中加锁。此操作无论成功与否都会立即返回。 <a href="structresumef_1_1mutex__t.html#a1dd128870c1fdcc7261ef0fa63e12254">更多...</a><br /></td></tr>
  107. <tr class="separator:a1dd128870c1fdcc7261ef0fa63e12254"><td class="memSeparator" colspan="2">&#160;</td></tr>
  108. <tr class="memitem:a15c6518dafb6c2cf52a0b0dbdd90ae7b"><td class="memTemplParams" colspan="2">template&lt;class _Rep , class _Period &gt; </td></tr>
  109. <tr class="memitem:a15c6518dafb6c2cf52a0b0dbdd90ae7b"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a15c6518dafb6c2cf52a0b0dbdd90ae7b">try_lock_for</a> (const std::chrono::duration&lt; _Rep, _Period &gt; &amp;dt, void *unique_address)</td></tr>
  110. <tr class="memdesc:a15c6518dafb6c2cf52a0b0dbdd90ae7b"><td class="mdescLeft">&#160;</td><td class="mdescRight">尝试在非协程中加锁,直到超时。如果不能立即获得锁,则反复尝试,直到获得锁或超时。故会阻塞当前协程 <a href="structresumef_1_1mutex__t.html#a15c6518dafb6c2cf52a0b0dbdd90ae7b">更多...</a><br /></td></tr>
  111. <tr class="separator:a15c6518dafb6c2cf52a0b0dbdd90ae7b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  112. <tr class="memitem:aec072ad5fd0d6b688a3866ee9f1dc791"><td class="memTemplParams" colspan="2">template&lt;class _Rep , class _Period &gt; </td></tr>
  113. <tr class="memitem:aec072ad5fd0d6b688a3866ee9f1dc791"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#aec072ad5fd0d6b688a3866ee9f1dc791">try_lock_until</a> (const std::chrono::time_point&lt; _Rep, _Period &gt; &amp;tp, void *unique_address)</td></tr>
  114. <tr class="memdesc:aec072ad5fd0d6b688a3866ee9f1dc791"><td class="mdescLeft">&#160;</td><td class="mdescRight">尝试在非协程中加锁,直到超时。如果不能立即获得锁,则反复尝试,直到获得锁或超时。故会阻塞当前协程 <a href="structresumef_1_1mutex__t.html#aec072ad5fd0d6b688a3866ee9f1dc791">更多...</a><br /></td></tr>
  115. <tr class="separator:aec072ad5fd0d6b688a3866ee9f1dc791"><td class="memSeparator" colspan="2">&#160;</td></tr>
  116. <tr class="memitem:abc858a566d0884726740557f930ec7db"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#abc858a566d0884726740557f930ec7db">unlock</a> (void *unique_address) const</td></tr>
  117. <tr class="memdesc:abc858a566d0884726740557f930ec7db"><td class="mdescLeft">&#160;</td><td class="mdescRight">在非协程中解锁。立即返回。由于立即返回,也可在协程中如此使用:mtx.unlock(root_state()) <a href="structresumef_1_1mutex__t.html#abc858a566d0884726740557f930ec7db">更多...</a><br /></td></tr>
  118. <tr class="separator:abc858a566d0884726740557f930ec7db"><td class="memSeparator" colspan="2">&#160;</td></tr>
  119. <tr class="memitem:a597d0ca4a0f0d9963d0578afb5aa1ecf"><td class="memItemLeft" align="right" valign="top"><a id="a597d0ca4a0f0d9963d0578afb5aa1ecf"></a>
  120. &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a597d0ca4a0f0d9963d0578afb5aa1ecf">mutex_t</a> (std::adopt_lock_t) noexcept</td></tr>
  121. <tr class="memdesc:a597d0ca4a0f0d9963d0578afb5aa1ecf"><td class="mdescLeft">&#160;</td><td class="mdescRight">构造一个无效的mutex_t。 <br /></td></tr>
  122. <tr class="separator:a597d0ca4a0f0d9963d0578afb5aa1ecf"><td class="memSeparator" colspan="2">&#160;</td></tr>
  123. </table><table class="memberdecls">
  124. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
  125. 静态 Public 成员函数</h2></td></tr>
  126. <tr class="memitem:ae2aecf303188c9a8122e3fde4fb525fd"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  127. <tr class="memitem:ae2aecf303188c9a8122e3fde4fb525fd"><td class="memTemplItemLeft" align="right" valign="top">static <a class="el" href="structresumef_1_1future__t.html">future_t</a>&lt; <a class="el" href="structresumef_1_1batch__unlock__t.html">batch_unlock_t</a>&lt; _Mtxs... &gt; &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#ae2aecf303188c9a8122e3fde4fb525fd">lock</a> (_Mtxs &amp;... mtxs)</td></tr>
  128. <tr class="memdesc:ae2aecf303188c9a8122e3fde4fb525fd"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中,无死锁的批量加锁。不会阻塞当前线程。直到获得所有锁之前,会阻塞当前协程。 <a href="structresumef_1_1mutex__t.html#ae2aecf303188c9a8122e3fde4fb525fd">更多...</a><br /></td></tr>
  129. <tr class="separator:ae2aecf303188c9a8122e3fde4fb525fd"><td class="memSeparator" colspan="2">&#160;</td></tr>
  130. <tr class="memitem:ae7f95d070a020cfeaf99684a06c5fd47"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  131. <tr class="memitem:ae7f95d070a020cfeaf99684a06c5fd47"><td class="memTemplItemLeft" align="right" valign="top">static <a class="el" href="structresumef_1_1future__t.html">future_t</a>&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#ae7f95d070a020cfeaf99684a06c5fd47">lock</a> (<a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a> manual_unlock_tag, _Mtxs &amp;... mtxs)</td></tr>
  132. <tr class="memdesc:ae7f95d070a020cfeaf99684a06c5fd47"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中,无死锁的批量加锁。不会阻塞当前线程。直到获得所有锁之前,会阻塞当前协程。 <a href="structresumef_1_1mutex__t.html#ae7f95d070a020cfeaf99684a06c5fd47">更多...</a><br /></td></tr>
  133. <tr class="separator:ae7f95d070a020cfeaf99684a06c5fd47"><td class="memSeparator" colspan="2">&#160;</td></tr>
  134. <tr class="memitem:a0bc0948ed9eab5e41518ff9c1a6327a3"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  135. <tr class="memitem:a0bc0948ed9eab5e41518ff9c1a6327a3"><td class="memTemplItemLeft" align="right" valign="top">static <a class="el" href="structresumef_1_1future__t.html">future_t</a>&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a0bc0948ed9eab5e41518ff9c1a6327a3">unlock</a> (_Mtxs &amp;... mtxs)</td></tr>
  136. <tr class="memdesc:a0bc0948ed9eab5e41518ff9c1a6327a3"><td class="mdescLeft">&#160;</td><td class="mdescRight">在协程中批量解锁。如果可能,使用unlock(root_state(), mtxs...)来替代。 <a href="structresumef_1_1mutex__t.html#a0bc0948ed9eab5e41518ff9c1a6327a3">更多...</a><br /></td></tr>
  137. <tr class="separator:a0bc0948ed9eab5e41518ff9c1a6327a3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  138. <tr class="memitem:ad7ba090cf3188eaa738d4e37a4c6ab7a"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  139. <tr class="memitem:ad7ba090cf3188eaa738d4e37a4c6ab7a"><td class="memTemplItemLeft" align="right" valign="top">static <a class="el" href="structresumef_1_1batch__unlock__t.html">batch_unlock_t</a>&lt; _Mtxs... &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#ad7ba090cf3188eaa738d4e37a4c6ab7a">lock</a> (void *unique_address, _Mtxs &amp;... mtxs)</td></tr>
  140. <tr class="memdesc:ad7ba090cf3188eaa738d4e37a4c6ab7a"><td class="mdescLeft">&#160;</td><td class="mdescRight">在非协程中,无死锁的批量加锁。会阻塞当前线程,直到获得所有锁为止。 <a href="structresumef_1_1mutex__t.html#ad7ba090cf3188eaa738d4e37a4c6ab7a">更多...</a><br /></td></tr>
  141. <tr class="separator:ad7ba090cf3188eaa738d4e37a4c6ab7a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  142. <tr class="memitem:abfbfd653a04d3c3b3d88a5bdcaba4664"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  143. <tr class="memitem:abfbfd653a04d3c3b3d88a5bdcaba4664"><td class="memTemplItemLeft" align="right" valign="top">static void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#abfbfd653a04d3c3b3d88a5bdcaba4664">lock</a> (<a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a> manual_unlock_tag, void *unique_address, _Mtxs &amp;... mtxs)</td></tr>
  144. <tr class="memdesc:abfbfd653a04d3c3b3d88a5bdcaba4664"><td class="mdescLeft">&#160;</td><td class="mdescRight">在非协程中,无死锁的批量加锁。会阻塞当前线程,直到获得所有锁为止。 <a href="structresumef_1_1mutex__t.html#abfbfd653a04d3c3b3d88a5bdcaba4664">更多...</a><br /></td></tr>
  145. <tr class="separator:abfbfd653a04d3c3b3d88a5bdcaba4664"><td class="memSeparator" colspan="2">&#160;</td></tr>
  146. <tr class="memitem:a28defd5d64173ef3114a419f945adb3d"><td class="memTemplParams" colspan="2">template&lt;class... _Mtxs&gt; </td></tr>
  147. <tr class="memitem:a28defd5d64173ef3114a419f945adb3d"><td class="memTemplItemLeft" align="right" valign="top">static void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="structresumef_1_1mutex__t.html#a28defd5d64173ef3114a419f945adb3d">unlock</a> (void *unique_address, _Mtxs &amp;... mtxs)</td></tr>
  148. <tr class="memdesc:a28defd5d64173ef3114a419f945adb3d"><td class="mdescLeft">&#160;</td><td class="mdescRight">在非协程中批量解锁。立即返回。由于立即返回,也可在协程中如此使用:unlock(root_state(), mtxs...) <a href="structresumef_1_1mutex__t.html#a28defd5d64173ef3114a419f945adb3d">更多...</a><br /></td></tr>
  149. <tr class="separator:a28defd5d64173ef3114a419f945adb3d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  150. </table>
  151. <a name="details" id="details"></a><h2 class="groupheader">详细描述</h2>
  152. <div class="textblock"><p>支持递归的锁。 </p>
  153. <p>锁被本协程所在的跟协程所拥有。支持在跟协程下的所有协程里递归加锁。 </p>
  154. </div><h2 class="groupheader">成员函数说明</h2>
  155. <a id="a15c654948f47113fc92223a811d60090"></a>
  156. <h2 class="memtitle"><span class="permalink"><a href="#a15c654948f47113fc92223a811d60090">&#9670;&nbsp;</a></span>lock() <span class="overload">[1/7]</span></h2>
  157. <div class="memitem">
  158. <div class="memproto">
  159. <table class="mlabels">
  160. <tr>
  161. <td class="mlabels-left">
  162. <table class="memname">
  163. <tr>
  164. <td class="memname">awaiter resumef::mutex_t::lock </td>
  165. <td>(</td>
  166. <td class="paramname"></td><td>)</td>
  167. <td> const</td>
  168. </tr>
  169. </table>
  170. </td>
  171. <td class="mlabels-right">
  172. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  173. </tr>
  174. </table>
  175. </div><div class="memdoc">
  176. <p>在协程中加锁,如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 </p>
  177. <dl class="section return"><dt>返回</dt><dd>[co_await] batch_unlock_t </dd></dl>
  178. </div>
  179. </div>
  180. <a id="ae2aecf303188c9a8122e3fde4fb525fd"></a>
  181. <h2 class="memtitle"><span class="permalink"><a href="#ae2aecf303188c9a8122e3fde4fb525fd">&#9670;&nbsp;</a></span>lock() <span class="overload">[2/7]</span></h2>
  182. <div class="memitem">
  183. <div class="memproto">
  184. <div class="memtemplate">
  185. template&lt;class... _Mtxs&gt; </div>
  186. <table class="mlabels">
  187. <tr>
  188. <td class="mlabels-left">
  189. <table class="memname">
  190. <tr>
  191. <td class="memname">static <a class="el" href="structresumef_1_1future__t.html">future_t</a>&lt;<a class="el" href="structresumef_1_1batch__unlock__t.html">batch_unlock_t</a>&lt;_Mtxs...&gt; &gt; resumef::mutex_t::lock </td>
  192. <td>(</td>
  193. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  194. <td class="paramname"><em>mtxs</em></td><td>)</td>
  195. <td></td>
  196. </tr>
  197. </table>
  198. </td>
  199. <td class="mlabels-right">
  200. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  201. </tr>
  202. </table>
  203. </div><div class="memdoc">
  204. <p>在协程中,无死锁的批量加锁。不会阻塞当前线程。直到获得所有锁之前,会阻塞当前协程。 </p>
  205. <dl class="params"><dt>参数</dt><dd>
  206. <table class="params">
  207. <tr><td class="paramname">mtxs...</td><td>需要获得的锁列表。 </td></tr>
  208. </table>
  209. </dd>
  210. </dl>
  211. <dl class="section return"><dt>返回</dt><dd>[co_await] batch_unlock_t </dd></dl>
  212. </div>
  213. </div>
  214. <a id="aad074e28785741eb1615d3126da6088a"></a>
  215. <h2 class="memtitle"><span class="permalink"><a href="#aad074e28785741eb1615d3126da6088a">&#9670;&nbsp;</a></span>lock() <span class="overload">[3/7]</span></h2>
  216. <div class="memitem">
  217. <div class="memproto">
  218. <table class="mlabels">
  219. <tr>
  220. <td class="mlabels-left">
  221. <table class="memname">
  222. <tr>
  223. <td class="memname">manual_awaiter resumef::mutex_t::lock </td>
  224. <td>(</td>
  225. <td class="paramtype"><a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a>&#160;</td>
  226. <td class="paramname"><em>manual_unlock_tag</em></td><td>)</td>
  227. <td> const</td>
  228. </tr>
  229. </table>
  230. </td>
  231. <td class="mlabels-right">
  232. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  233. </tr>
  234. </table>
  235. </div><div class="memdoc">
  236. <p>在协程中加锁,如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 </p>
  237. <p>需要随后调用unlock()函数解锁。lock()/unlock()调用必须在同一个跟协程下配对调用。 </p><dl class="params"><dt>参数</dt><dd>
  238. <table class="params">
  239. <tr><td class="paramname">manual_unlock_tag</td><td>提示手工解锁 </td></tr>
  240. </table>
  241. </dd>
  242. </dl>
  243. <dl class="section return"><dt>返回</dt><dd>[co_await] void </dd></dl>
  244. </div>
  245. </div>
  246. <a id="ae7f95d070a020cfeaf99684a06c5fd47"></a>
  247. <h2 class="memtitle"><span class="permalink"><a href="#ae7f95d070a020cfeaf99684a06c5fd47">&#9670;&nbsp;</a></span>lock() <span class="overload">[4/7]</span></h2>
  248. <div class="memitem">
  249. <div class="memproto">
  250. <div class="memtemplate">
  251. template&lt;class... _Mtxs&gt; </div>
  252. <table class="mlabels">
  253. <tr>
  254. <td class="mlabels-left">
  255. <table class="memname">
  256. <tr>
  257. <td class="memname">static <a class="el" href="structresumef_1_1future__t.html">future_t</a> resumef::mutex_t::lock </td>
  258. <td>(</td>
  259. <td class="paramtype"><a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a>&#160;</td>
  260. <td class="paramname"><em>manual_unlock_tag</em>, </td>
  261. </tr>
  262. <tr>
  263. <td class="paramkey"></td>
  264. <td></td>
  265. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  266. <td class="paramname"><em>mtxs</em>&#160;</td>
  267. </tr>
  268. <tr>
  269. <td></td>
  270. <td>)</td>
  271. <td></td><td></td>
  272. </tr>
  273. </table>
  274. </td>
  275. <td class="mlabels-right">
  276. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  277. </tr>
  278. </table>
  279. </div><div class="memdoc">
  280. <p>在协程中,无死锁的批量加锁。不会阻塞当前线程。直到获得所有锁之前,会阻塞当前协程。 </p>
  281. <dl class="params"><dt>参数</dt><dd>
  282. <table class="params">
  283. <tr><td class="paramname">manual_unlock_tag</td><td>提示手工解锁 </td></tr>
  284. <tr><td class="paramname">mtxs...</td><td>需要获得的锁列表。 </td></tr>
  285. </table>
  286. </dd>
  287. </dl>
  288. <dl class="section return"><dt>返回</dt><dd>[co_await] void </dd></dl>
  289. </div>
  290. </div>
  291. <a id="abfbfd653a04d3c3b3d88a5bdcaba4664"></a>
  292. <h2 class="memtitle"><span class="permalink"><a href="#abfbfd653a04d3c3b3d88a5bdcaba4664">&#9670;&nbsp;</a></span>lock() <span class="overload">[5/7]</span></h2>
  293. <div class="memitem">
  294. <div class="memproto">
  295. <div class="memtemplate">
  296. template&lt;class... _Mtxs&gt; </div>
  297. <table class="mlabels">
  298. <tr>
  299. <td class="mlabels-left">
  300. <table class="memname">
  301. <tr>
  302. <td class="memname">static void resumef::mutex_t::lock </td>
  303. <td>(</td>
  304. <td class="paramtype"><a class="el" href="structresumef_1_1adopt__manual__unlock__t.html">adopt_manual_unlock_t</a>&#160;</td>
  305. <td class="paramname"><em>manual_unlock_tag</em>, </td>
  306. </tr>
  307. <tr>
  308. <td class="paramkey"></td>
  309. <td></td>
  310. <td class="paramtype">void *&#160;</td>
  311. <td class="paramname"><em>unique_address</em>, </td>
  312. </tr>
  313. <tr>
  314. <td class="paramkey"></td>
  315. <td></td>
  316. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  317. <td class="paramname"><em>mtxs</em>&#160;</td>
  318. </tr>
  319. <tr>
  320. <td></td>
  321. <td>)</td>
  322. <td></td><td></td>
  323. </tr>
  324. </table>
  325. </td>
  326. <td class="mlabels-right">
  327. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  328. </tr>
  329. </table>
  330. </div><div class="memdoc">
  331. <p>在非协程中,无死锁的批量加锁。会阻塞当前线程,直到获得所有锁为止。 </p>
  332. <dl class="params"><dt>参数</dt><dd>
  333. <table class="params">
  334. <tr><td class="paramname">manual_unlock_tag</td><td>提示手工解锁 </td></tr>
  335. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  336. <tr><td class="paramname">mtxs...</td><td>需要获得的锁列表。 </td></tr>
  337. </table>
  338. </dd>
  339. </dl>
  340. </div>
  341. </div>
  342. <a id="a3442f7c56bed34e086bd5bd41e4a9c5a"></a>
  343. <h2 class="memtitle"><span class="permalink"><a href="#a3442f7c56bed34e086bd5bd41e4a9c5a">&#9670;&nbsp;</a></span>lock() <span class="overload">[6/7]</span></h2>
  344. <div class="memitem">
  345. <div class="memproto">
  346. <table class="memname">
  347. <tr>
  348. <td class="memname">void resumef::mutex_t::lock </td>
  349. <td>(</td>
  350. <td class="paramtype">void *&#160;</td>
  351. <td class="paramname"><em>unique_address</em></td><td>)</td>
  352. <td> const</td>
  353. </tr>
  354. </table>
  355. </div><div class="memdoc">
  356. <p>在非协程中加锁。如果不能立即获得锁,则反复尝试,直到获得锁。故会阻塞当前协程 </p>
  357. <dl class="params"><dt>参数</dt><dd>
  358. <table class="params">
  359. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。此地址应当与随后的unlock()的地址一致。<br />
  360. 一般做法,是申明一个跟当前线程关联的局部变量,以此局部变量的地址为参数。 </td></tr>
  361. </table>
  362. </dd>
  363. </dl>
  364. </div>
  365. </div>
  366. <a id="ad7ba090cf3188eaa738d4e37a4c6ab7a"></a>
  367. <h2 class="memtitle"><span class="permalink"><a href="#ad7ba090cf3188eaa738d4e37a4c6ab7a">&#9670;&nbsp;</a></span>lock() <span class="overload">[7/7]</span></h2>
  368. <div class="memitem">
  369. <div class="memproto">
  370. <div class="memtemplate">
  371. template&lt;class... _Mtxs&gt; </div>
  372. <table class="mlabels">
  373. <tr>
  374. <td class="mlabels-left">
  375. <table class="memname">
  376. <tr>
  377. <td class="memname">static <a class="el" href="structresumef_1_1batch__unlock__t.html">batch_unlock_t</a>&lt;_Mtxs...&gt; resumef::mutex_t::lock </td>
  378. <td>(</td>
  379. <td class="paramtype">void *&#160;</td>
  380. <td class="paramname"><em>unique_address</em>, </td>
  381. </tr>
  382. <tr>
  383. <td class="paramkey"></td>
  384. <td></td>
  385. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  386. <td class="paramname"><em>mtxs</em>&#160;</td>
  387. </tr>
  388. <tr>
  389. <td></td>
  390. <td>)</td>
  391. <td></td><td></td>
  392. </tr>
  393. </table>
  394. </td>
  395. <td class="mlabels-right">
  396. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  397. </tr>
  398. </table>
  399. </div><div class="memdoc">
  400. <p>在非协程中,无死锁的批量加锁。会阻塞当前线程,直到获得所有锁为止。 </p>
  401. <dl class="params"><dt>参数</dt><dd>
  402. <table class="params">
  403. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  404. <tr><td class="paramname">mtxs...</td><td>需要获得的锁列表。 </td></tr>
  405. </table>
  406. </dd>
  407. </dl>
  408. <dl class="section return"><dt>返回</dt><dd>batch_unlock_t </dd></dl>
  409. </div>
  410. </div>
  411. <a id="a9f086f150094d041b0c4372a8de504de"></a>
  412. <h2 class="memtitle"><span class="permalink"><a href="#a9f086f150094d041b0c4372a8de504de">&#9670;&nbsp;</a></span>operator co_await()</h2>
  413. <div class="memitem">
  414. <div class="memproto">
  415. <table class="mlabels">
  416. <tr>
  417. <td class="mlabels-left">
  418. <table class="memname">
  419. <tr>
  420. <td class="memname">awaiter resumef::mutex_t::operator co_await </td>
  421. <td>(</td>
  422. <td class="paramname"></td><td>)</td>
  423. <td> const</td>
  424. </tr>
  425. </table>
  426. </td>
  427. <td class="mlabels-right">
  428. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  429. </tr>
  430. </table>
  431. </div><div class="memdoc">
  432. <p>在协程中加锁。 </p>
  433. <dl class="section see"><dt>参见</dt><dd>等同调用 co_await <a class="el" href="structresumef_1_1mutex__t.html#a15c654948f47113fc92223a811d60090" title="在协程中加锁,如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。">lock()</a>。 </dd></dl>
  434. <dl class="section return"><dt>返回</dt><dd>[co_await] batch_unlock_t </dd></dl>
  435. </div>
  436. </div>
  437. <a id="a2844d5df6562c153bc5b32d1720efb30"></a>
  438. <h2 class="memtitle"><span class="permalink"><a href="#a2844d5df6562c153bc5b32d1720efb30">&#9670;&nbsp;</a></span>try_lock() <span class="overload">[1/2]</span></h2>
  439. <div class="memitem">
  440. <div class="memproto">
  441. <table class="mlabels">
  442. <tr>
  443. <td class="mlabels-left">
  444. <table class="memname">
  445. <tr>
  446. <td class="memname">try_awaiter resumef::mutex_t::try_lock </td>
  447. <td>(</td>
  448. <td class="paramname"></td><td>)</td>
  449. <td> const</td>
  450. </tr>
  451. </table>
  452. </td>
  453. <td class="mlabels-right">
  454. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  455. </tr>
  456. </table>
  457. </div><div class="memdoc">
  458. <p>尝试在协程中加锁。此操作无论成功与否都会立即返回,不会有协程切换。 </p>
  459. <p>如果加锁成功,则需要调用co_await <a class="el" href="structresumef_1_1mutex__t.html#a430ec9f4b9bb1c5711b6ba7ef3a1ad99" title="在协程中解锁。此操作立即返回,不会有协程切换。">unlock()</a>解锁。或者使用unlock(root_state())解锁。<br />
  460. 如果加锁失败,且要循环尝试加锁,则最好调用co_await yield()让出一次调度。否则,可能造成本调度器死循环。 </p><dl class="section return"><dt>返回</dt><dd>[co_await] bool </dd></dl>
  461. </div>
  462. </div>
  463. <a id="a1dd128870c1fdcc7261ef0fa63e12254"></a>
  464. <h2 class="memtitle"><span class="permalink"><a href="#a1dd128870c1fdcc7261ef0fa63e12254">&#9670;&nbsp;</a></span>try_lock() <span class="overload">[2/2]</span></h2>
  465. <div class="memitem">
  466. <div class="memproto">
  467. <table class="memname">
  468. <tr>
  469. <td class="memname">bool resumef::mutex_t::try_lock </td>
  470. <td>(</td>
  471. <td class="paramtype">void *&#160;</td>
  472. <td class="paramname"><em>unique_address</em></td><td>)</td>
  473. <td> const</td>
  474. </tr>
  475. </table>
  476. </div><div class="memdoc">
  477. <p>尝试在非协程中加锁。此操作无论成功与否都会立即返回。 </p>
  478. <dl class="params"><dt>参数</dt><dd>
  479. <table class="params">
  480. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  481. </table>
  482. </dd>
  483. </dl>
  484. </div>
  485. </div>
  486. <a id="afca20661d92d6acac34b324cab774310"></a>
  487. <h2 class="memtitle"><span class="permalink"><a href="#afca20661d92d6acac34b324cab774310">&#9670;&nbsp;</a></span>try_lock_for() <span class="overload">[1/2]</span></h2>
  488. <div class="memitem">
  489. <div class="memproto">
  490. <div class="memtemplate">
  491. template&lt;class _Rep , class _Period &gt; </div>
  492. <table class="mlabels">
  493. <tr>
  494. <td class="mlabels-left">
  495. <table class="memname">
  496. <tr>
  497. <td class="memname">timeout_awaiter resumef::mutex_t::try_lock_for </td>
  498. <td>(</td>
  499. <td class="paramtype">const std::chrono::duration&lt; _Rep, _Period &gt; &amp;&#160;</td>
  500. <td class="paramname"><em>dt</em></td><td>)</td>
  501. <td> const</td>
  502. </tr>
  503. </table>
  504. </td>
  505. <td class="mlabels-right">
  506. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  507. </tr>
  508. </table>
  509. </div><div class="memdoc">
  510. <p>在协程中尝试加锁,直到超时。如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 </p>
  511. <dl class="params"><dt>参数</dt><dd>
  512. <table class="params">
  513. <tr><td class="paramname">dt</td><td>超时时长 </td></tr>
  514. </table>
  515. </dd>
  516. </dl>
  517. <dl class="section return"><dt>返回</dt><dd>[co_await] bool </dd></dl>
  518. </div>
  519. </div>
  520. <a id="a15c6518dafb6c2cf52a0b0dbdd90ae7b"></a>
  521. <h2 class="memtitle"><span class="permalink"><a href="#a15c6518dafb6c2cf52a0b0dbdd90ae7b">&#9670;&nbsp;</a></span>try_lock_for() <span class="overload">[2/2]</span></h2>
  522. <div class="memitem">
  523. <div class="memproto">
  524. <div class="memtemplate">
  525. template&lt;class _Rep , class _Period &gt; </div>
  526. <table class="memname">
  527. <tr>
  528. <td class="memname">bool resumef::mutex_t::try_lock_for </td>
  529. <td>(</td>
  530. <td class="paramtype">const std::chrono::duration&lt; _Rep, _Period &gt; &amp;&#160;</td>
  531. <td class="paramname"><em>dt</em>, </td>
  532. </tr>
  533. <tr>
  534. <td class="paramkey"></td>
  535. <td></td>
  536. <td class="paramtype">void *&#160;</td>
  537. <td class="paramname"><em>unique_address</em>&#160;</td>
  538. </tr>
  539. <tr>
  540. <td></td>
  541. <td>)</td>
  542. <td></td><td></td>
  543. </tr>
  544. </table>
  545. </div><div class="memdoc">
  546. <p>尝试在非协程中加锁,直到超时。如果不能立即获得锁,则反复尝试,直到获得锁或超时。故会阻塞当前协程 </p>
  547. <dl class="params"><dt>参数</dt><dd>
  548. <table class="params">
  549. <tr><td class="paramname">dt</td><td>超时时长 </td></tr>
  550. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  551. </table>
  552. </dd>
  553. </dl>
  554. </div>
  555. </div>
  556. <a id="ada9a310ff364fa8b1ee78dc2f799a8a5"></a>
  557. <h2 class="memtitle"><span class="permalink"><a href="#ada9a310ff364fa8b1ee78dc2f799a8a5">&#9670;&nbsp;</a></span>try_lock_until() <span class="overload">[1/2]</span></h2>
  558. <div class="memitem">
  559. <div class="memproto">
  560. <div class="memtemplate">
  561. template&lt;class _Rep , class _Period &gt; </div>
  562. <table class="mlabels">
  563. <tr>
  564. <td class="mlabels-left">
  565. <table class="memname">
  566. <tr>
  567. <td class="memname">timeout_awaiter resumef::mutex_t::try_lock_until </td>
  568. <td>(</td>
  569. <td class="paramtype">const std::chrono::time_point&lt; _Rep, _Period &gt; &amp;&#160;</td>
  570. <td class="paramname"><em>tp</em></td><td>)</td>
  571. <td> const</td>
  572. </tr>
  573. </table>
  574. </td>
  575. <td class="mlabels-right">
  576. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  577. </tr>
  578. </table>
  579. </div><div class="memdoc">
  580. <p>在协程中尝试加锁,直到超时。如果不能立即获得锁,则阻塞当前协程。但不会阻塞当前线程。 </p>
  581. <dl class="params"><dt>参数</dt><dd>
  582. <table class="params">
  583. <tr><td class="paramname">tp</td><td>超时时刻 </td></tr>
  584. </table>
  585. </dd>
  586. </dl>
  587. <dl class="section return"><dt>返回</dt><dd>[co_await] bool </dd></dl>
  588. </div>
  589. </div>
  590. <a id="aec072ad5fd0d6b688a3866ee9f1dc791"></a>
  591. <h2 class="memtitle"><span class="permalink"><a href="#aec072ad5fd0d6b688a3866ee9f1dc791">&#9670;&nbsp;</a></span>try_lock_until() <span class="overload">[2/2]</span></h2>
  592. <div class="memitem">
  593. <div class="memproto">
  594. <div class="memtemplate">
  595. template&lt;class _Rep , class _Period &gt; </div>
  596. <table class="memname">
  597. <tr>
  598. <td class="memname">bool resumef::mutex_t::try_lock_until </td>
  599. <td>(</td>
  600. <td class="paramtype">const std::chrono::time_point&lt; _Rep, _Period &gt; &amp;&#160;</td>
  601. <td class="paramname"><em>tp</em>, </td>
  602. </tr>
  603. <tr>
  604. <td class="paramkey"></td>
  605. <td></td>
  606. <td class="paramtype">void *&#160;</td>
  607. <td class="paramname"><em>unique_address</em>&#160;</td>
  608. </tr>
  609. <tr>
  610. <td></td>
  611. <td>)</td>
  612. <td></td><td></td>
  613. </tr>
  614. </table>
  615. </div><div class="memdoc">
  616. <p>尝试在非协程中加锁,直到超时。如果不能立即获得锁,则反复尝试,直到获得锁或超时。故会阻塞当前协程 </p>
  617. <dl class="params"><dt>参数</dt><dd>
  618. <table class="params">
  619. <tr><td class="paramname">tp</td><td>超时时刻 </td></tr>
  620. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  621. </table>
  622. </dd>
  623. </dl>
  624. </div>
  625. </div>
  626. <a id="a430ec9f4b9bb1c5711b6ba7ef3a1ad99"></a>
  627. <h2 class="memtitle"><span class="permalink"><a href="#a430ec9f4b9bb1c5711b6ba7ef3a1ad99">&#9670;&nbsp;</a></span>unlock() <span class="overload">[1/4]</span></h2>
  628. <div class="memitem">
  629. <div class="memproto">
  630. <table class="mlabels">
  631. <tr>
  632. <td class="mlabels-left">
  633. <table class="memname">
  634. <tr>
  635. <td class="memname">unlock_awaiter resumef::mutex_t::unlock </td>
  636. <td>(</td>
  637. <td class="paramname"></td><td>)</td>
  638. <td> const</td>
  639. </tr>
  640. </table>
  641. </td>
  642. <td class="mlabels-right">
  643. <span class="mlabels"><span class="mlabel">noexcept</span></span> </td>
  644. </tr>
  645. </table>
  646. </div><div class="memdoc">
  647. <p>在协程中解锁。此操作立即返回,不会有协程切换。 </p>
  648. <dl class="section return"><dt>返回</dt><dd>[co_await] void </dd></dl>
  649. </div>
  650. </div>
  651. <a id="a0bc0948ed9eab5e41518ff9c1a6327a3"></a>
  652. <h2 class="memtitle"><span class="permalink"><a href="#a0bc0948ed9eab5e41518ff9c1a6327a3">&#9670;&nbsp;</a></span>unlock() <span class="overload">[2/4]</span></h2>
  653. <div class="memitem">
  654. <div class="memproto">
  655. <div class="memtemplate">
  656. template&lt;class... _Mtxs&gt; </div>
  657. <table class="mlabels">
  658. <tr>
  659. <td class="mlabels-left">
  660. <table class="memname">
  661. <tr>
  662. <td class="memname">static <a class="el" href="structresumef_1_1future__t.html">future_t</a> resumef::mutex_t::unlock </td>
  663. <td>(</td>
  664. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  665. <td class="paramname"><em>mtxs</em></td><td>)</td>
  666. <td></td>
  667. </tr>
  668. </table>
  669. </td>
  670. <td class="mlabels-right">
  671. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  672. </tr>
  673. </table>
  674. </div><div class="memdoc">
  675. <p>在协程中批量解锁。如果可能,使用unlock(root_state(), mtxs...)来替代。 </p>
  676. <dl class="params"><dt>参数</dt><dd>
  677. <table class="params">
  678. <tr><td class="paramname">mtxs...</td><td>需要解锁的锁列表。 </td></tr>
  679. </table>
  680. </dd>
  681. </dl>
  682. <dl class="section return"><dt>返回</dt><dd>[co_await] void </dd></dl>
  683. </div>
  684. </div>
  685. <a id="abc858a566d0884726740557f930ec7db"></a>
  686. <h2 class="memtitle"><span class="permalink"><a href="#abc858a566d0884726740557f930ec7db">&#9670;&nbsp;</a></span>unlock() <span class="overload">[3/4]</span></h2>
  687. <div class="memitem">
  688. <div class="memproto">
  689. <table class="memname">
  690. <tr>
  691. <td class="memname">void resumef::mutex_t::unlock </td>
  692. <td>(</td>
  693. <td class="paramtype">void *&#160;</td>
  694. <td class="paramname"><em>unique_address</em></td><td>)</td>
  695. <td> const</td>
  696. </tr>
  697. </table>
  698. </div><div class="memdoc">
  699. <p>在非协程中解锁。立即返回。由于立即返回,也可在协程中如此使用:mtx.unlock(root_state()) </p>
  700. <dl class="params"><dt>参数</dt><dd>
  701. <table class="params">
  702. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  703. </table>
  704. </dd>
  705. </dl>
  706. </div>
  707. </div>
  708. <a id="a28defd5d64173ef3114a419f945adb3d"></a>
  709. <h2 class="memtitle"><span class="permalink"><a href="#a28defd5d64173ef3114a419f945adb3d">&#9670;&nbsp;</a></span>unlock() <span class="overload">[4/4]</span></h2>
  710. <div class="memitem">
  711. <div class="memproto">
  712. <div class="memtemplate">
  713. template&lt;class... _Mtxs&gt; </div>
  714. <table class="mlabels">
  715. <tr>
  716. <td class="mlabels-left">
  717. <table class="memname">
  718. <tr>
  719. <td class="memname">static void resumef::mutex_t::unlock </td>
  720. <td>(</td>
  721. <td class="paramtype">void *&#160;</td>
  722. <td class="paramname"><em>unique_address</em>, </td>
  723. </tr>
  724. <tr>
  725. <td class="paramkey"></td>
  726. <td></td>
  727. <td class="paramtype">_Mtxs &amp;...&#160;</td>
  728. <td class="paramname"><em>mtxs</em>&#160;</td>
  729. </tr>
  730. <tr>
  731. <td></td>
  732. <td>)</td>
  733. <td></td><td></td>
  734. </tr>
  735. </table>
  736. </td>
  737. <td class="mlabels-right">
  738. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  739. </tr>
  740. </table>
  741. </div><div class="memdoc">
  742. <p>在非协程中批量解锁。立即返回。由于立即返回,也可在协程中如此使用:unlock(root_state(), mtxs...) </p>
  743. <dl class="params"><dt>参数</dt><dd>
  744. <table class="params">
  745. <tr><td class="paramname">unique_address</td><td>代表获得锁的拥有者。 </td></tr>
  746. <tr><td class="paramname">mtxs...</td><td>需要解锁的锁列表。 </td></tr>
  747. </table>
  748. </dd>
  749. </dl>
  750. </div>
  751. </div>
  752. <hr/>该结构体的文档由以下文件生成:<ul>
  753. <li>librf/src/<a class="el" href="mutex__v2_8h_source.html">mutex_v2.h</a></li>
  754. </ul>
  755. </div><!-- contents -->
  756. <!-- start footer part -->
  757. <hr class="footer"/><address class="footer"><small>
  758. 制作者 &#160;<a href="http://www.doxygen.org/index.html">
  759. <img class="footer" src="doxygen.png" alt="doxygen"/>
  760. </a> 1.8.17
  761. </small></address>
  762. </body>
  763. </html>