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.
		
		
		
		
		
			
		
			
				
					
					
						
							174 lines
						
					
					
						
							10 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							174 lines
						
					
					
						
							10 KiB
						
					
					
				| <!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"/> | |
| <meta name="generator" content="Doxygen 1.8.4"/> | |
| <title>tbb::spin_mutex Class 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! --> | |
| <!-- end header part --> | |
| <!-- Generated by Doxygen 1.8.4 --> | |
|   <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="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="a00222.html">tbb</a></li><li class="navelem"><a class="el" href="a00127.html">spin_mutex</a></li>  </ul> | |
| </div> | |
| </div><!-- top --> | |
| <div class="header"> | |
|   <div class="summary"> | |
| <a href="#nested-classes">Classes</a> | | |
| <a href="#pub-methods">Public Member Functions</a> | | |
| <a href="#pub-static-attribs">Static Public Attributes</a> | | |
| <a href="#friends">Friends</a> | | |
| <a href="a00281.html">List of all members</a>  </div> | |
|   <div class="headertitle"> | |
| <div class="title">tbb::spin_mutex Class Reference<div class="ingroups"><a class="el" href="a00237.html">Synchronization</a></div></div>  </div> | |
| </div><!--header--> | |
| <div class="contents"> | |
| 
 | |
| <p>A lock that occupies a single byte.   | |
|  <a href="a00127.html#details">More...</a></p> | |
| 
 | |
| <p><code>#include <spin_mutex.h></code></p> | |
| <table class="memberdecls"> | |
| <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a> | |
| Classes</h2></td></tr> | |
| <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class  </td><td class="memItemRight" valign="bottom"><a class="el" href="a00113.html">scoped_lock</a></td></tr> | |
| <tr class="memdesc:"><td class="mdescLeft"> </td><td class="mdescRight">Represents acquisition of a mutex.  <a href="a00113.html#details">More...</a><br/></td></tr> | |
| <tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr> | |
| </table><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:a6c96196965bf7df426311d282ad3c378"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="a00127.html#a6c96196965bf7df426311d282ad3c378">spin_mutex</a> ()</td></tr> | |
| <tr class="memdesc:a6c96196965bf7df426311d282ad3c378"><td class="mdescLeft"> </td><td class="mdescRight">Construct unacquired lock.  <a href="#a6c96196965bf7df426311d282ad3c378">More...</a><br/></td></tr> | |
| <tr class="separator:a6c96196965bf7df426311d282ad3c378"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:a4ec484f4df6ec5595ec821ef20bd6cd7"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a4ec484f4df6ec5595ec821ef20bd6cd7"></a> | |
| void __TBB_EXPORTED_METHOD </td><td class="memItemRight" valign="bottom"><a class="el" href="a00127.html#a4ec484f4df6ec5595ec821ef20bd6cd7">internal_construct</a> ()</td></tr> | |
| <tr class="memdesc:a4ec484f4df6ec5595ec821ef20bd6cd7"><td class="mdescLeft"> </td><td class="mdescRight">Internal constructor with ITT instrumentation. <br/></td></tr> | |
| <tr class="separator:a4ec484f4df6ec5595ec821ef20bd6cd7"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:a8957e40b0781192419d01d28e5205ec4"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a8957e40b0781192419d01d28e5205ec4"></a> | |
| void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00127.html#a8957e40b0781192419d01d28e5205ec4">lock</a> ()</td></tr> | |
| <tr class="memdesc:a8957e40b0781192419d01d28e5205ec4"><td class="mdescLeft"> </td><td class="mdescRight">Acquire lock. <br/></td></tr> | |
| <tr class="separator:a8957e40b0781192419d01d28e5205ec4"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:a003ffb196d22bf22ca22142338b7eeab"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="a00127.html#a003ffb196d22bf22ca22142338b7eeab">try_lock</a> ()</td></tr> | |
| <tr class="memdesc:a003ffb196d22bf22ca22142338b7eeab"><td class="mdescLeft"> </td><td class="mdescRight">Try acquiring lock (non-blocking)  <a href="#a003ffb196d22bf22ca22142338b7eeab">More...</a><br/></td></tr> | |
| <tr class="separator:a003ffb196d22bf22ca22142338b7eeab"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:adfcf8fe840aa73c08c2cadd570fd48fd"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="adfcf8fe840aa73c08c2cadd570fd48fd"></a> | |
| void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00127.html#adfcf8fe840aa73c08c2cadd570fd48fd">unlock</a> ()</td></tr> | |
| <tr class="memdesc:adfcf8fe840aa73c08c2cadd570fd48fd"><td class="mdescLeft"> </td><td class="mdescRight">Release lock. <br/></td></tr> | |
| <tr class="separator:adfcf8fe840aa73c08c2cadd570fd48fd"><td class="memSeparator" colspan="2"> </td></tr> | |
| </table><table class="memberdecls"> | |
| <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-attribs"></a> | |
| Static Public Attributes</h2></td></tr> | |
| <tr class="memitem:a7c3354db4bd5cc81bccee9f249abb9e8"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7c3354db4bd5cc81bccee9f249abb9e8"></a> | |
| static const bool </td><td class="memItemRight" valign="bottom"><b>is_rw_mutex</b> = false</td></tr> | |
| <tr class="separator:a7c3354db4bd5cc81bccee9f249abb9e8"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:a0cae048c5dc5deffe75464e4a3a2b752"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0cae048c5dc5deffe75464e4a3a2b752"></a> | |
| static const bool </td><td class="memItemRight" valign="bottom"><b>is_recursive_mutex</b> = false</td></tr> | |
| <tr class="separator:a0cae048c5dc5deffe75464e4a3a2b752"><td class="memSeparator" colspan="2"> </td></tr> | |
| <tr class="memitem:ad00ec9a97f34c9160300950b36deac3e"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad00ec9a97f34c9160300950b36deac3e"></a> | |
| static const bool </td><td class="memItemRight" valign="bottom"><b>is_fair_mutex</b> = false</td></tr> | |
| <tr class="separator:ad00ec9a97f34c9160300950b36deac3e"><td class="memSeparator" colspan="2"> </td></tr> | |
| </table><table class="memberdecls"> | |
| <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="friends"></a> | |
| Friends</h2></td></tr> | |
| <tr class="memitem:afcf922650b2fd9d76b7b939d8511bbd8"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afcf922650b2fd9d76b7b939d8511bbd8"></a> | |
| class </td><td class="memItemRight" valign="bottom"><b>scoped_lock</b></td></tr> | |
| <tr class="separator:afcf922650b2fd9d76b7b939d8511bbd8"><td class="memSeparator" colspan="2"> </td></tr> | |
| </table> | |
| <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> | |
| <div class="textblock"><p>A lock that occupies a single byte. </p> | |
| <p>A <a class="el" href="a00127.html" title="A lock that occupies a single byte. ">spin_mutex</a> is a spin mutex that fits in a single byte. It should be used only for locking short critical sections (typically less than 20 instructions) when fairness is not an issue. If zero-initialized, the mutex is considered unheld. </p> | |
| </div><h2 class="groupheader">Constructor & Destructor Documentation</h2> | |
| <a class="anchor" id="a6c96196965bf7df426311d282ad3c378"></a> | |
| <div class="memitem"> | |
| <div class="memproto"> | |
| <table class="mlabels"> | |
|   <tr> | |
|   <td class="mlabels-left"> | |
|       <table class="memname"> | |
|         <tr> | |
|           <td class="memname">tbb::spin_mutex::spin_mutex </td> | |
|           <td>(</td> | |
|           <td class="paramname">)</td><td></td> | |
|           <td></td> | |
|         </tr> | |
|       </table> | |
|   </td> | |
|   <td class="mlabels-right"> | |
| <span class="mlabels"><span class="mlabel">inline</span></span>  </td> | |
|   </tr> | |
| </table> | |
| </div><div class="memdoc"> | |
| 
 | |
| <p>Construct unacquired lock. </p> | |
| <p>Equivalent to zero-initialization of *this. </p> | |
| 
 | |
| <p>References <a class="el" href="a00127.html#a4ec484f4df6ec5595ec821ef20bd6cd7">internal_construct()</a>.</p> | |
| 
 | |
| </div> | |
| </div> | |
| <h2 class="groupheader">Member Function Documentation</h2> | |
| <a class="anchor" id="a003ffb196d22bf22ca22142338b7eeab"></a> | |
| <div class="memitem"> | |
| <div class="memproto"> | |
| <table class="mlabels"> | |
|   <tr> | |
|   <td class="mlabels-left"> | |
|       <table class="memname"> | |
|         <tr> | |
|           <td class="memname">bool tbb::spin_mutex::try_lock </td> | |
|           <td>(</td> | |
|           <td class="paramname">)</td><td></td> | |
|           <td></td> | |
|         </tr> | |
|       </table> | |
|   </td> | |
|   <td class="mlabels-right"> | |
| <span class="mlabels"><span class="mlabel">inline</span></span>  </td> | |
|   </tr> | |
| </table> | |
| </div><div class="memdoc"> | |
| 
 | |
| <p>Try acquiring lock (non-blocking) </p> | |
| <p>Return true if lock acquired; false otherwise. </p> | |
| 
 | |
| <p>References <a class="el" href="a00014.html#a3525dbbac0d4eaedfe18bc57b7760857">tbb::aligned_space< T, N >::begin()</a>.</p> | |
| 
 | |
| </div> | |
| </div> | |
| <hr/>The documentation for this class was generated from the following file:<ul> | |
| <li>spin_mutex.h</li> | |
| </ul> | |
| </div><!-- contents --> | |
| <hr> | |
| <p></p> | |
| Copyright © 2005-2014 Intel Corporation.  All Rights Reserved. | |
| <p></p> | |
| Intel, Pentium, Intel Xeon, Itanium, Intel XScale and VTune are | |
| registered trademarks or trademarks of Intel Corporation or its | |
| subsidiaries in the United States and other countries. | |
| <p></p> | |
| * Other names and brands may be claimed as the property of others.
 |