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.
		
		
		
		
		
			
		
			
				
					
					
						
							433 lines
						
					
					
						
							30 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							433 lines
						
					
					
						
							30 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::interface5::concurrent_priority_queue< T, Compare, A > 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! -->
							 | 
						|
								<!-- 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"><b>interface5</b></li><li class="navelem"><a class="el" href="a00037.html">concurrent_priority_queue</a></li>  </ul>
							 | 
						|
								</div>
							 | 
						|
								</div><!-- top -->
							 | 
						|
								<div class="header">
							 | 
						|
								  <div class="summary">
							 | 
						|
								<a href="#nested-classes">Classes</a> |
							 | 
						|
								<a href="#pub-types">Public Types</a> |
							 | 
						|
								<a href="#pub-methods">Public Member Functions</a> |
							 | 
						|
								<a href="a00339.html">List of all members</a>  </div>
							 | 
						|
								  <div class="headertitle">
							 | 
						|
								<div class="title">tbb::interface5::concurrent_priority_queue< T, Compare, A > Class Template Reference</div>  </div>
							 | 
						|
								</div><!--header-->
							 | 
						|
								<div class="contents">
							 | 
						|
								
							 | 
						|
								<p>Concurrent priority queue.  
							 | 
						|
								 <a href="a00037.html#details">More...</a></p>
							 | 
						|
								
							 | 
						|
								<p><code>#include <concurrent_priority_queue.h></code></p>
							 | 
						|
								<table class="memberdecls">
							 | 
						|
								<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
							 | 
						|
								Public Types</h2></td></tr>
							 | 
						|
								<tr class="memitem:a2c75d97ae429019363ab6fd1a872512e"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a2c75d97ae429019363ab6fd1a872512e"></a>
							 | 
						|
								typedef T </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a2c75d97ae429019363ab6fd1a872512e">value_type</a></td></tr>
							 | 
						|
								<tr class="memdesc:a2c75d97ae429019363ab6fd1a872512e"><td class="mdescLeft"> </td><td class="mdescRight">Element type in the queue. <br/></td></tr>
							 | 
						|
								<tr class="separator:a2c75d97ae429019363ab6fd1a872512e"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:ae4b7ed2ddc8ec6cc910f935c9d299c7a"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ae4b7ed2ddc8ec6cc910f935c9d299c7a"></a>
							 | 
						|
								typedef T & </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#ae4b7ed2ddc8ec6cc910f935c9d299c7a">reference</a></td></tr>
							 | 
						|
								<tr class="memdesc:ae4b7ed2ddc8ec6cc910f935c9d299c7a"><td class="mdescLeft"> </td><td class="mdescRight">Reference type. <br/></td></tr>
							 | 
						|
								<tr class="separator:ae4b7ed2ddc8ec6cc910f935c9d299c7a"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a0bd617fe8e4657777e86f0ae15d8094f"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0bd617fe8e4657777e86f0ae15d8094f"></a>
							 | 
						|
								typedef const T & </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a0bd617fe8e4657777e86f0ae15d8094f">const_reference</a></td></tr>
							 | 
						|
								<tr class="memdesc:a0bd617fe8e4657777e86f0ae15d8094f"><td class="mdescLeft"> </td><td class="mdescRight">Const reference type. <br/></td></tr>
							 | 
						|
								<tr class="separator:a0bd617fe8e4657777e86f0ae15d8094f"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a7d3da9b47ec58e1c09e3550f702edcfc"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7d3da9b47ec58e1c09e3550f702edcfc"></a>
							 | 
						|
								typedef size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a7d3da9b47ec58e1c09e3550f702edcfc">size_type</a></td></tr>
							 | 
						|
								<tr class="memdesc:a7d3da9b47ec58e1c09e3550f702edcfc"><td class="mdescLeft"> </td><td class="mdescRight">Integral type for representing size of the queue. <br/></td></tr>
							 | 
						|
								<tr class="separator:a7d3da9b47ec58e1c09e3550f702edcfc"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:ae010b1fa9c0942504737228474b51a0b"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ae010b1fa9c0942504737228474b51a0b"></a>
							 | 
						|
								typedef ptrdiff_t </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#ae010b1fa9c0942504737228474b51a0b">difference_type</a></td></tr>
							 | 
						|
								<tr class="memdesc:ae010b1fa9c0942504737228474b51a0b"><td class="mdescLeft"> </td><td class="mdescRight">Difference type for iterator. <br/></td></tr>
							 | 
						|
								<tr class="separator:ae010b1fa9c0942504737228474b51a0b"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a1d2cebf242fa83d88eebdc3ad6891fb1"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a1d2cebf242fa83d88eebdc3ad6891fb1"></a>
							 | 
						|
								typedef A </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a></td></tr>
							 | 
						|
								<tr class="memdesc:a1d2cebf242fa83d88eebdc3ad6891fb1"><td class="mdescLeft"> </td><td class="mdescRight">Allocator type. <br/></td></tr>
							 | 
						|
								<tr class="separator:a1d2cebf242fa83d88eebdc3ad6891fb1"><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:a405be01bac4048f214797c287e2571a1"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a405be01bac4048f214797c287e2571a1"></a>
							 | 
						|
								 </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a405be01bac4048f214797c287e2571a1">concurrent_priority_queue</a> (const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> &a=<a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a>())</td></tr>
							 | 
						|
								<tr class="memdesc:a405be01bac4048f214797c287e2571a1"><td class="mdescLeft"> </td><td class="mdescRight">Constructs a new <a class="el" href="a00037.html" title="Concurrent priority queue. ">concurrent_priority_queue</a> with default capacity. <br/></td></tr>
							 | 
						|
								<tr class="separator:a405be01bac4048f214797c287e2571a1"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a43c3917ea8a19cf1fec947e29ad4ff3e"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a43c3917ea8a19cf1fec947e29ad4ff3e"></a>
							 | 
						|
								 </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a43c3917ea8a19cf1fec947e29ad4ff3e">concurrent_priority_queue</a> (<a class="el" href="a00037.html#a7d3da9b47ec58e1c09e3550f702edcfc">size_type</a> init_capacity, const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> &a=<a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a>())</td></tr>
							 | 
						|
								<tr class="memdesc:a43c3917ea8a19cf1fec947e29ad4ff3e"><td class="mdescLeft"> </td><td class="mdescRight">Constructs a new <a class="el" href="a00037.html" title="Concurrent priority queue. ">concurrent_priority_queue</a> with init_sz capacity. <br/></td></tr>
							 | 
						|
								<tr class="separator:a43c3917ea8a19cf1fec947e29ad4ff3e"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a0cebee26cc0d00d4dcbb1c74e08029f7"><td class="memTemplParams" colspan="2"><a class="anchor" id="a0cebee26cc0d00d4dcbb1c74e08029f7"></a>
							 | 
						|
								template<typename InputIterator > </td></tr>
							 | 
						|
								<tr class="memitem:a0cebee26cc0d00d4dcbb1c74e08029f7"><td class="memTemplItemLeft" align="right" valign="top"> </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00037.html#a0cebee26cc0d00d4dcbb1c74e08029f7">concurrent_priority_queue</a> (InputIterator begin, InputIterator end, const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> &a=<a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a>())</td></tr>
							 | 
						|
								<tr class="memdesc:a0cebee26cc0d00d4dcbb1c74e08029f7"><td class="mdescLeft"> </td><td class="mdescRight">[begin,end) constructor <br/></td></tr>
							 | 
						|
								<tr class="separator:a0cebee26cc0d00d4dcbb1c74e08029f7"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a111763d621fa792f281c2a13bd3e5edf"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a111763d621fa792f281c2a13bd3e5edf"></a>
							 | 
						|
								 </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a111763d621fa792f281c2a13bd3e5edf">concurrent_priority_queue</a> (std::initializer_list< T > const &init_list, const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> &a=<a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a>())</td></tr>
							 | 
						|
								<tr class="memdesc:a111763d621fa792f281c2a13bd3e5edf"><td class="mdescLeft"> </td><td class="mdescRight">Constructor from std::initializer_list. <br/></td></tr>
							 | 
						|
								<tr class="separator:a111763d621fa792f281c2a13bd3e5edf"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a332d26234f9c37a6b7ba269c648815d0"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a332d26234f9c37a6b7ba269c648815d0">concurrent_priority_queue</a> (const <a class="el" href="a00037.html">concurrent_priority_queue</a> &src)</td></tr>
							 | 
						|
								<tr class="memdesc:a332d26234f9c37a6b7ba269c648815d0"><td class="mdescLeft"> </td><td class="mdescRight">Copy constructor.  <a href="#a332d26234f9c37a6b7ba269c648815d0">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a332d26234f9c37a6b7ba269c648815d0"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:aa52cea369b6630699ee78cc42622be9d"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#aa52cea369b6630699ee78cc42622be9d">concurrent_priority_queue</a> (const <a class="el" href="a00037.html">concurrent_priority_queue</a> &src, const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> &a)</td></tr>
							 | 
						|
								<tr class="memdesc:aa52cea369b6630699ee78cc42622be9d"><td class="mdescLeft"> </td><td class="mdescRight">Copy constructor with specific allocator.  <a href="#aa52cea369b6630699ee78cc42622be9d">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:aa52cea369b6630699ee78cc42622be9d"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:ac0c3f41b10f04547f3438517c40cf8a5"><td class="memItemLeft" align="right" valign="top"><a class="el" href="a00037.html">concurrent_priority_queue</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#ac0c3f41b10f04547f3438517c40cf8a5">operator=</a> (const <a class="el" href="a00037.html">concurrent_priority_queue</a> &src)</td></tr>
							 | 
						|
								<tr class="memdesc:ac0c3f41b10f04547f3438517c40cf8a5"><td class="mdescLeft"> </td><td class="mdescRight">Assignment operator.  <a href="#ac0c3f41b10f04547f3438517c40cf8a5">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:ac0c3f41b10f04547f3438517c40cf8a5"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:ac64c7b627708f0d6b2e5421fb0d49150"><td class="memTemplParams" colspan="2"><a class="anchor" id="ac64c7b627708f0d6b2e5421fb0d49150"></a>
							 | 
						|
								template<typename InputIterator > </td></tr>
							 | 
						|
								<tr class="memitem:ac64c7b627708f0d6b2e5421fb0d49150"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00037.html#ac64c7b627708f0d6b2e5421fb0d49150">assign</a> (InputIterator begin, InputIterator end)</td></tr>
							 | 
						|
								<tr class="memdesc:ac64c7b627708f0d6b2e5421fb0d49150"><td class="mdescLeft"> </td><td class="mdescRight">Assign the queue from [begin,end) range, not thread-safe. <br/></td></tr>
							 | 
						|
								<tr class="separator:ac64c7b627708f0d6b2e5421fb0d49150"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:ada4a58867572d9ff340c6692a226d457"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ada4a58867572d9ff340c6692a226d457"></a>
							 | 
						|
								void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#ada4a58867572d9ff340c6692a226d457">assign</a> (std::initializer_list< T > const &il)</td></tr>
							 | 
						|
								<tr class="memdesc:ada4a58867572d9ff340c6692a226d457"><td class="mdescLeft"> </td><td class="mdescRight">Assign the queue from std::initializer_list, not thread-safe. <br/></td></tr>
							 | 
						|
								<tr class="separator:ada4a58867572d9ff340c6692a226d457"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a32eb9c65caf399b62fac7c13e65af05f"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a32eb9c65caf399b62fac7c13e65af05f"></a>
							 | 
						|
								<a class="el" href="a00037.html">concurrent_priority_queue</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a32eb9c65caf399b62fac7c13e65af05f">operator=</a> (std::initializer_list< T > const &il)</td></tr>
							 | 
						|
								<tr class="memdesc:a32eb9c65caf399b62fac7c13e65af05f"><td class="mdescLeft"> </td><td class="mdescRight">Assign from std::initializer_list, not thread-safe. <br/></td></tr>
							 | 
						|
								<tr class="separator:a32eb9c65caf399b62fac7c13e65af05f"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a8dec2dd0e8b22af14f1753eaef1bf5eb"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a8dec2dd0e8b22af14f1753eaef1bf5eb">empty</a> () const </td></tr>
							 | 
						|
								<tr class="memdesc:a8dec2dd0e8b22af14f1753eaef1bf5eb"><td class="mdescLeft"> </td><td class="mdescRight">Returns true if empty, false otherwise.  <a href="#a8dec2dd0e8b22af14f1753eaef1bf5eb">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a8dec2dd0e8b22af14f1753eaef1bf5eb"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a7d86ba200474b51ec99a6b917429c6bb"><td class="memItemLeft" align="right" valign="top"><a class="el" href="a00037.html#a7d3da9b47ec58e1c09e3550f702edcfc">size_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a7d86ba200474b51ec99a6b917429c6bb">size</a> () const </td></tr>
							 | 
						|
								<tr class="memdesc:a7d86ba200474b51ec99a6b917429c6bb"><td class="mdescLeft"> </td><td class="mdescRight">Returns the current number of elements contained in the queue.  <a href="#a7d86ba200474b51ec99a6b917429c6bb">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a7d86ba200474b51ec99a6b917429c6bb"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a1bfa0e7269b3407d6bb5c706264d2406"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a1bfa0e7269b3407d6bb5c706264d2406">push</a> (<a class="el" href="a00037.html#a0bd617fe8e4657777e86f0ae15d8094f">const_reference</a> elem)</td></tr>
							 | 
						|
								<tr class="memdesc:a1bfa0e7269b3407d6bb5c706264d2406"><td class="mdescLeft"> </td><td class="mdescRight">Pushes elem onto the queue, increasing capacity of queue if necessary.  <a href="#a1bfa0e7269b3407d6bb5c706264d2406">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a1bfa0e7269b3407d6bb5c706264d2406"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a954177b09e184cf3db47f1b180a7ef5e"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a954177b09e184cf3db47f1b180a7ef5e">try_pop</a> (<a class="el" href="a00037.html#ae4b7ed2ddc8ec6cc910f935c9d299c7a">reference</a> elem)</td></tr>
							 | 
						|
								<tr class="memdesc:a954177b09e184cf3db47f1b180a7ef5e"><td class="mdescLeft"> </td><td class="mdescRight">Gets a reference to and removes highest priority element.  <a href="#a954177b09e184cf3db47f1b180a7ef5e">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a954177b09e184cf3db47f1b180a7ef5e"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a2459166998a4103880d603b237c429e6"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a2459166998a4103880d603b237c429e6">clear</a> ()</td></tr>
							 | 
						|
								<tr class="memdesc:a2459166998a4103880d603b237c429e6"><td class="mdescLeft"> </td><td class="mdescRight">Clear the queue; not thread-safe.  <a href="#a2459166998a4103880d603b237c429e6">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:a2459166998a4103880d603b237c429e6"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:aa6ee6d356e538b67a7cb4e242e6e36c9"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#aa6ee6d356e538b67a7cb4e242e6e36c9">swap</a> (<a class="el" href="a00037.html">concurrent_priority_queue</a> &q)</td></tr>
							 | 
						|
								<tr class="memdesc:aa6ee6d356e538b67a7cb4e242e6e36c9"><td class="mdescLeft"> </td><td class="mdescRight">Swap this queue with another; not thread-safe.  <a href="#aa6ee6d356e538b67a7cb4e242e6e36c9">More...</a><br/></td></tr>
							 | 
						|
								<tr class="separator:aa6ee6d356e538b67a7cb4e242e6e36c9"><td class="memSeparator" colspan="2"> </td></tr>
							 | 
						|
								<tr class="memitem:a312e88e51246da4c516d35abbb30721a"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a312e88e51246da4c516d35abbb30721a"></a>
							 | 
						|
								<a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="a00037.html#a312e88e51246da4c516d35abbb30721a">get_allocator</a> () const </td></tr>
							 | 
						|
								<tr class="memdesc:a312e88e51246da4c516d35abbb30721a"><td class="mdescLeft"> </td><td class="mdescRight">Return allocator object. <br/></td></tr>
							 | 
						|
								<tr class="separator:a312e88e51246da4c516d35abbb30721a"><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<typename T, typename Compare = std::less<T>, typename A = cache_aligned_allocator<T>><br/>
							 | 
						|
								class tbb::interface5::concurrent_priority_queue< T, Compare, A ></h3>
							 | 
						|
								
							 | 
						|
								<p>Concurrent priority queue. </p>
							 | 
						|
								</div><h2 class="groupheader">Constructor & Destructor Documentation</h2>
							 | 
						|
								<a class="anchor" id="a332d26234f9c37a6b7ba269c648815d0"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname"><a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::<a class="el" href="a00037.html">concurrent_priority_queue</a> </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype">const <a class="el" href="a00037.html">concurrent_priority_queue</a>< T, Compare, A > & </td>
							 | 
						|
								          <td class="paramname"><em>src</em>)</td><td></td>
							 | 
						|
								          <td></td>
							 | 
						|
								        </tr>
							 | 
						|
								      </table>
							 | 
						|
								  </td>
							 | 
						|
								  <td class="mlabels-right">
							 | 
						|
								<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">explicit</span></span>  </td>
							 | 
						|
								  </tr>
							 | 
						|
								</table>
							 | 
						|
								</div><div class="memdoc">
							 | 
						|
								
							 | 
						|
								<p>Copy constructor. </p>
							 | 
						|
								<p>This operation is unsafe if there are pending concurrent operations on the src queue. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="aa52cea369b6630699ee78cc42622be9d"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname"><a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::<a class="el" href="a00037.html">concurrent_priority_queue</a> </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype">const <a class="el" href="a00037.html">concurrent_priority_queue</a>< T, Compare, A > & </td>
							 | 
						|
								          <td class="paramname"><em>src</em>, </td>
							 | 
						|
								        </tr>
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="paramkey"></td>
							 | 
						|
								          <td></td>
							 | 
						|
								          <td class="paramtype">const <a class="el" href="a00037.html#a1d2cebf242fa83d88eebdc3ad6891fb1">allocator_type</a> & </td>
							 | 
						|
								          <td class="paramname"><em>a</em> </td>
							 | 
						|
								        </tr>
							 | 
						|
								        <tr>
							 | 
						|
								          <td></td>
							 | 
						|
								          <td>)</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>Copy constructor with specific allocator. </p>
							 | 
						|
								<p>This operation is unsafe if there are pending concurrent operations on the src queue. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<h2 class="groupheader">Member Function Documentation</h2>
							 | 
						|
								<a class="anchor" id="a2459166998a4103880d603b237c429e6"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname">void <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::clear </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>Clear the queue; not thread-safe. </p>
							 | 
						|
								<p>This operation is unsafe if there are pending concurrent operations on the queue. Resets size, effectively emptying queue; does not free space. May not clear elements added in pending operations. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="a8dec2dd0e8b22af14f1753eaef1bf5eb"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname">bool <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::empty </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramname">)</td><td></td>
							 | 
						|
								          <td> const</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>Returns true if empty, false otherwise. </p>
							 | 
						|
								<p>Returned value may not reflect results of pending operations. This operation reads shared data and will trigger a race condition. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="ac0c3f41b10f04547f3438517c40cf8a5"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname"><a class="el" href="a00037.html">concurrent_priority_queue</a>& <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::operator= </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype">const <a class="el" href="a00037.html">concurrent_priority_queue</a>< T, Compare, A > & </td>
							 | 
						|
								          <td class="paramname"><em>src</em>)</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>Assignment operator. </p>
							 | 
						|
								<p>This operation is unsafe if there are pending concurrent operations on the src queue. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="a1bfa0e7269b3407d6bb5c706264d2406"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname">void <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::push </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype"><a class="el" href="a00037.html#a0bd617fe8e4657777e86f0ae15d8094f">const_reference</a> </td>
							 | 
						|
								          <td class="paramname"><em>elem</em>)</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>Pushes elem onto the queue, increasing capacity of queue if necessary. </p>
							 | 
						|
								<p>This operation can be safely used concurrently with other push, try_pop or reserve operations. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="a7d86ba200474b51ec99a6b917429c6bb"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname"><a class="el" href="a00037.html#a7d3da9b47ec58e1c09e3550f702edcfc">size_type</a> <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::size </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramname">)</td><td></td>
							 | 
						|
								          <td> const</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>Returns the current number of elements contained in the queue. </p>
							 | 
						|
								<p>Returned value may not reflect results of pending operations. This operation reads shared data and will trigger a race condition. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="aa6ee6d356e538b67a7cb4e242e6e36c9"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname">void <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::swap </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype"><a class="el" href="a00037.html">concurrent_priority_queue</a>< T, Compare, A > & </td>
							 | 
						|
								          <td class="paramname"><em>q</em>)</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>Swap this queue with another; not thread-safe. </p>
							 | 
						|
								<p>This operation is unsafe if there are pending concurrent operations on the queue. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<a class="anchor" id="a954177b09e184cf3db47f1b180a7ef5e"></a>
							 | 
						|
								<div class="memitem">
							 | 
						|
								<div class="memproto">
							 | 
						|
								<div class="memtemplate">
							 | 
						|
								template<typename T , typename Compare  = std::less<T>, typename A  = cache_aligned_allocator<T>> </div>
							 | 
						|
								<table class="mlabels">
							 | 
						|
								  <tr>
							 | 
						|
								  <td class="mlabels-left">
							 | 
						|
								      <table class="memname">
							 | 
						|
								        <tr>
							 | 
						|
								          <td class="memname">bool <a class="el" href="a00037.html">tbb::interface5::concurrent_priority_queue</a>< T, Compare, A >::try_pop </td>
							 | 
						|
								          <td>(</td>
							 | 
						|
								          <td class="paramtype"><a class="el" href="a00037.html#ae4b7ed2ddc8ec6cc910f935c9d299c7a">reference</a> </td>
							 | 
						|
								          <td class="paramname"><em>elem</em>)</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>Gets a reference to and removes highest priority element. </p>
							 | 
						|
								<p>If a highest priority element was found, sets elem and returns true, otherwise returns false. This operation can be safely used concurrently with other push, try_pop or reserve operations. </p>
							 | 
						|
								
							 | 
						|
								</div>
							 | 
						|
								</div>
							 | 
						|
								<hr/>The documentation for this class was generated from the following file:<ul>
							 | 
						|
								<li>concurrent_priority_queue.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.
							 |