<!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"/> <title>libstdc++: __gnu_parallel::_QSBThreadLocal< _RAIter > Struct Template Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <link href="navtree.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="navtree.js"></script> <script type="text/javascript" src="resize.js"></script> <script type="text/javascript"> $(document).ready(initResizable); </script> <link href="doxygen.css" rel="stylesheet" type="text/css"/> </head> <body> <!-- Generated by Doxygen 1.7.4 --> <div id="top"> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td style="padding-left: 0.5em;"> <div id="projectname">libstdc++</div> </td> </tr> </tbody> </table> </div> </div> <div id="side-nav" class="ui-resizable side-nav-resizable"> <div id="nav-tree"> <div id="nav-tree-contents"> </div> </div> <div id="splitbar" style="-moz-user-select:none;" class="ui-resizable-handle"> </div> </div> <script type="text/javascript"> initNavTree('a00153.html',''); </script> <div id="doc-content"> <div class="header"> <div class="summary"> <a href="#pub-types">Public Types</a> | <a href="#pub-methods">Public Member Functions</a> | <a href="#pub-attribs">Public Attributes</a> </div> <div class="headertitle"> <div class="title">__gnu_parallel::_QSBThreadLocal< _RAIter > Struct Template Reference</div> </div> </div> <div class="contents"> <!-- doxytag: class="__gnu_parallel::_QSBThreadLocal" --> <p>Information local to one thread in the parallel quicksort run. <a href="a00153.html#details">More...</a></p> <p><a href="a01627.html">List of all members.</a></p> <h2><a name="pub-types"></a> Public Types</h2> <ul> <li><a class="anchor" id="a6c8c7846694fcbd41d9cbfcd26bf9e0f"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_DifferenceType" ref="a6c8c7846694fcbd41d9cbfcd26bf9e0f" args="" --> typedef <br class="typebreak"/> _TraitsType::difference_type <b>_DifferenceType</b> <li>typedef <a class="el" href="a00263.html">std::pair</a>< _RAIter, <br class="typebreak"/> _RAIter > <a class="el" href="a00153.html#a4b151f36b1cac07063a9e6ae1ae9fd5a">_Piece</a> <li><a class="anchor" id="a1fb2f487e249373accb75cdb89928c93"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_TraitsType" ref="a1fb2f487e249373accb75cdb89928c93" args="" --> typedef std::iterator_traits<br class="typebreak"/> < _RAIter > <b>_TraitsType</b> </ul> <h2><a name="pub-methods"></a> Public Member Functions</h2> <ul> <li><a class="el" href="a00153.html#a47e9a744d2981943c13ac5a0af56f493">_QSBThreadLocal</a> (int __queue_size) </ul> <h2><a name="pub-attribs"></a> Public Attributes</h2> <ul> <li>volatile _DifferenceType * <a class="el" href="a00153.html#a02cf2d3081cda15fa671ec19cb62b551">_M_elements_leftover</a> <li><a class="el" href="a00263.html">_Piece</a> <a class="el" href="a00153.html#aba7a5f9235cc1a847e3754df018eb9b4">_M_global</a> <li><a class="el" href="a00263.html">_Piece</a> <a class="el" href="a00153.html#a0018330a1faea8911bb0a8a7ee44f72e">_M_initial</a> <li><a class="el" href="a00155.html">_RestrictedBoundedConcurrentQueue</a><br class="typebreak"/> < <a class="el" href="a00263.html">_Piece</a> > <a class="el" href="a00153.html#ab857deaace34709581c5573bc62afd49">_M_leftover_parts</a> <li><a class="el" href="a01131.html#a05e502e51bfc3233671730f74a44dc6a">_ThreadIndex</a> <a class="el" href="a00153.html#a0b63568837becdfbbd1f7accc1c05d1d">_M_num_threads</a> </ul> <hr/><a name="details" id="details"></a><h2>Detailed Description</h2> <div class="textblock"><h3>template<typename _RAIter><br/> struct __gnu_parallel::_QSBThreadLocal< _RAIter ></h3> <p>Information local to one thread in the parallel quicksort run. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00062">62</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> </div><hr/><h2>Member Typedef Documentation</h2> <a class="anchor" id="a4b151f36b1cac07063a9e6ae1ae9fd5a"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_Piece" ref="a4b151f36b1cac07063a9e6ae1ae9fd5a" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname">typedef <a class="el" href="a00263.html">std::pair</a><_RAIter, _RAIter> <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00263.html">_Piece</a></td> </tr> </table> </div> <div class="memdoc"> <p>Continuous part of the sequence, described by an iterator pair. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00069">69</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> </div> </div> <hr/><h2>Constructor & Destructor Documentation</h2> <a class="anchor" id="a47e9a744d2981943c13ac5a0af56f493"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_QSBThreadLocal" ref="a47e9a744d2981943c13ac5a0af56f493" args="(int __queue_size)" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html">_QSBThreadLocal</a> </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"><em>__queue_size</em></td><td>)</td> <td><code> [inline]</code></td> </tr> </table> </div> <div class="memdoc"> <p>Constructor. </p> <dl><dt><b>Parameters:</b></dt><dd> <table class="params"> <tr><td class="paramname">__queue_size</td><td>size of the work-stealing queue. </td></tr> </table> </dd> </dl> <p>Definition at line <a class="el" href="a00763_source.html#l00088">88</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> </div> </div> <hr/><h2>Member Data Documentation</h2> <a class="anchor" id="a02cf2d3081cda15fa671ec19cb62b551"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_M_elements_leftover" ref="a02cf2d3081cda15fa671ec19cb62b551" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname">volatile _DifferenceType* <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html#a02cf2d3081cda15fa671ec19cb62b551">_M_elements_leftover</a></td> </tr> </table> </div> <div class="memdoc"> <p>Pointer to a counter of elements left over to sort. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00081">81</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> <p>Referenced by <a class="el" href="a00763_source.html#l00430">__gnu_parallel::__parallel_sort_qsb()</a>, <a class="el" href="a00763_source.html#l00171">__gnu_parallel::__qsb_conquer()</a>, and <a class="el" href="a00763_source.html#l00247">__gnu_parallel::__qsb_local_sort_with_helping()</a>.</p> </div> </div> <a class="anchor" id="aba7a5f9235cc1a847e3754df018eb9b4"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_M_global" ref="aba7a5f9235cc1a847e3754df018eb9b4" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="a00263.html">_Piece</a> <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html#aba7a5f9235cc1a847e3754df018eb9b4">_M_global</a></td> </tr> </table> </div> <div class="memdoc"> <p>The complete sequence to sort. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00084">84</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> </div> </div> <a class="anchor" id="a0018330a1faea8911bb0a8a7ee44f72e"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_M_initial" ref="a0018330a1faea8911bb0a8a7ee44f72e" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="a00263.html">_Piece</a> <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html#a0018330a1faea8911bb0a8a7ee44f72e">_M_initial</a></td> </tr> </table> </div> <div class="memdoc"> <p>Initial piece to work on. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00072">72</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> <p>Referenced by <a class="el" href="a00763_source.html#l00171">__gnu_parallel::__qsb_conquer()</a>, and <a class="el" href="a00763_source.html#l00247">__gnu_parallel::__qsb_local_sort_with_helping()</a>.</p> </div> </div> <a class="anchor" id="ab857deaace34709581c5573bc62afd49"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_M_leftover_parts" ref="ab857deaace34709581c5573bc62afd49" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="a00155.html">_RestrictedBoundedConcurrentQueue</a><<a class="el" href="a00263.html">_Piece</a>> <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html#ab857deaace34709581c5573bc62afd49">_M_leftover_parts</a></td> </tr> </table> </div> <div class="memdoc"> <p>Work-stealing queue. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00075">75</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> <p>Referenced by <a class="el" href="a00763_source.html#l00247">__gnu_parallel::__qsb_local_sort_with_helping()</a>.</p> </div> </div> <a class="anchor" id="a0b63568837becdfbbd1f7accc1c05d1d"></a><!-- doxytag: member="__gnu_parallel::_QSBThreadLocal::_M_num_threads" ref="a0b63568837becdfbbd1f7accc1c05d1d" args="" --> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename _RAIter> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="a01131.html#a05e502e51bfc3233671730f74a44dc6a">_ThreadIndex</a> <a class="el" href="a00153.html">__gnu_parallel::_QSBThreadLocal</a>< _RAIter >::<a class="el" href="a00153.html#a0b63568837becdfbbd1f7accc1c05d1d">_M_num_threads</a></td> </tr> </table> </div> <div class="memdoc"> <p>Number of threads involved in this algorithm. </p> <p>Definition at line <a class="el" href="a00763_source.html#l00078">78</a> of file <a class="el" href="a00763_source.html">balanced_quicksort.h</a>.</p> <p>Referenced by <a class="el" href="a00763_source.html#l00247">__gnu_parallel::__qsb_local_sort_with_helping()</a>.</p> </div> </div> <hr/>The documentation for this struct was generated from the following file:<ul> <li><a class="el" href="a00763_source.html">balanced_quicksort.h</a></li> </ul> </div> </div> <div id="nav-path" class="navpath"> <ul> <li class="navelem"><a class="el" href="a01131.html">__gnu_parallel</a> </li> <li class="navelem"><a class="el" href="a00153.html">_QSBThreadLocal</a> </li> <li class="footer">Generated by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.4 </li> </ul> </div> </body> </html>