21 #ifndef __TBB_concurrent_vector_H 22 #define __TBB_concurrent_vector_H 33 #include __TBB_STD_SWAP_HEADER 39 #if _MSC_VER==1500 && !__INTEL_COMPILER 41 #pragma warning( push ) 42 #pragma warning( disable: 4985 ) 45 #if _MSC_VER==1500 && !__INTEL_COMPILER 46 #pragma warning( pop ) 49 #if __TBB_INITIALIZER_LISTS_PRESENT 50 #include <initializer_list> 53 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 55 #pragma warning (push) 57 #pragma warning (disable: 4267) 59 #pragma warning (disable: 4127) //warning C4127: conditional expression is constant 64 template<
typename T,
class A = cache_aligned_allocator<T> >
70 template<
typename Container,
typename Value>
79 std::memset( static_cast<void*>(array), 0, n_of_elements *
sizeof( T ) );
115 template<
typename argument_type>
119 T*
pointer()
const {
return static_cast<T*
>(
const_cast<void*
>(array)); }
139 tbb::internal::swap<relaxed>(array, rhs.
array);
147 template<memory_semantics M>
150 template<memory_semantics M>
155 template<memory_semantics M>
161 template<memory_semantics M>
164 "other overloads of store should be used for marking segment as not_used or allocation_failed" );
165 array.
store<M>(allocated_segment_pointer);
238 __TBB_ASSERT(element_index,
"there should be no need to call " 239 "is_first_element_in_segment for 0th element" );
280 template<
typename Container,
typename Value>
294 template<
typename Container,
typename Value>
307 template<
typename C,
typename T>
310 template<
typename C,
typename T,
typename U>
313 template<
typename C,
typename T,
typename U>
316 template<
typename C,
typename T,
typename U>
319 template<
typename C,
typename U>
320 friend class internal::vector_iterator;
322 #if !__TBB_TEMPLATE_FRIENDS_BROKEN 323 template<
typename T,
class A>
330 my_vector(const_cast<Container*>(&vector)),
332 my_item(static_cast<Value*>(ptr))
340 my_vector(other.my_vector),
341 my_index(other.my_index),
342 my_item(other.my_item)
362 Value* item = my_item;
364 item = my_item = &my_vector->internal_subscript(my_index);
366 __TBB_ASSERT( item==&my_vector->internal_subscript(my_index),
"corrupt cache" );
370 return my_vector->internal_subscript(my_index+k);
376 size_t element_index = ++my_index;
392 __TBB_ASSERT( my_index>0,
"operator--() applied to iterator already at beginning of concurrent_vector" );
393 size_t element_index = my_index--;
429 template<
typename Container,
typename T>
434 template<
typename Container,
typename T,
typename U>
439 template<
typename Container,
typename T,
typename U>
444 template<
typename Container,
typename T,
typename U>
449 template<
typename Container,
typename T,
typename U>
454 template<
typename Container,
typename T,
typename U>
459 template<
typename Container,
typename T,
typename U>
464 template<
typename Container,
typename T,
typename U>
469 template<
typename T,
class A>
542 template<
typename T,
class A>
560 template<
typename C,
typename U>
561 friend class internal::vector_iterator;
577 typedef internal::vector_iterator<concurrent_vector,T>
iterator;
580 #if !defined(_MSC_VER) || _CPPLIB_VER>=300 586 typedef std::reverse_iterator<iterator,T,T&,T*> reverse_iterator;
587 typedef std::reverse_iterator<const_iterator,T,const T&,const T*> const_reverse_iterator;
602 : internal::
allocator_base<T, A>(a), internal::concurrent_vector_base()
609 #if __TBB_INITIALIZER_LISTS_PRESENT 610 concurrent_vector(std::initializer_list<T> init_list,
const allocator_type &a = allocator_type())
616 internal_assign_iterators(init_list.begin(), init_list.end());
624 #endif //# __TBB_INITIALIZER_LISTS_PRESENT 628 : internal::
allocator_base<T, A>(a), internal::concurrent_vector_base()
640 #if __TBB_CPP11_RVALUE_REF_PRESENT 651 : internal::
allocator_base<T, A>(a), internal::concurrent_vector_base()
656 if (a == source.my_allocator) {
674 : internal::
allocator_base<T, A>(a), internal::concurrent_vector_base()
691 internal_resize( n,
sizeof(T), max_size(), NULL, &destroy_array, &initialize_array );
705 internal_resize( n,
sizeof(T), max_size(), static_cast<const void*>(&t), &destroy_array, &initialize_array_by );
720 internal_assign_range(first, last,
static_cast<is_integer_tag<std::numeric_limits<I>::is_integer
> *>(0) );
730 if(
this != &vector )
731 internal_assign(vector,
sizeof(T), &destroy_array, &assign_array, ©_array);
735 #if __TBB_CPP11_RVALUE_REF_PRESENT 739 __TBB_ASSERT(
this != &other,
"Move assignment to itself is prohibited ");
746 internal_assign(other,
sizeof(T), &destroy_array, &move_assign_array, &move_array);
756 if( static_cast<void*>(
this ) != static_cast<const void*>( &vector ) )
758 sizeof(T), &destroy_array, &assign_array, ©_array);
762 #if __TBB_INITIALIZER_LISTS_PRESENT 766 internal_assign_iterators(init_list.begin(), init_list.end());
769 #endif //#if __TBB_INITIALIZER_LISTS_PRESENT 782 iterator
grow_by( size_type delta, const_reference t ) {
789 typename std::iterator_traits<I>::difference_type delta = std::distance(first, last);
795 #if __TBB_INITIALIZER_LISTS_PRESENT 797 iterator
grow_by( std::initializer_list<T> init_list ) {
798 return grow_by( init_list.begin(), init_list.end() );
800 #endif //#if __TBB_INITIALIZER_LISTS_PRESENT 813 return iterator(*
this, m);
824 return iterator(*
this, m);
831 push_back_helper prolog(*
this);
832 new(prolog.internal_push_back_result()) T(item);
833 return prolog.return_iterator_and_dismiss();
836 #if __TBB_CPP11_RVALUE_REF_PRESENT 841 push_back_helper prolog(*
this);
842 new(prolog.internal_push_back_result()) T(
std::move(item));
843 return prolog.return_iterator_and_dismiss();
845 #if __TBB_CPP11_VARIADIC_TEMPLATES_PRESENT 848 template<
typename... Args>
851 push_back_helper prolog(*
this);
852 new(prolog.internal_push_back_result()) T(std::forward<Args>(args)...);
853 return prolog.return_iterator_and_dismiss();
855 #endif //__TBB_CPP11_VARIADIC_TEMPLATES_PRESENT 856 #endif //__TBB_CPP11_RVALUE_REF_PRESENT 861 return internal_subscript(index);
866 return internal_subscript(index);
870 reference
at( size_type index ) {
871 return internal_subscript_with_exceptions(index);
875 const_reference
at( size_type index )
const {
876 return internal_subscript_with_exceptions(index);
880 range_type
range(
size_t grainsize = 1 ) {
881 return range_type(
begin(),
end(), grainsize );
885 const_range_type
range(
size_t grainsize = 1 )
const {
886 return const_range_type(
begin(),
end(), grainsize );
895 return cp < sz ? cp : sz;
914 internal_resize( n,
sizeof(T), max_size(), NULL, &destroy_array, &initialize_array );
918 void resize( size_type n, const_reference t ) {
919 internal_resize( n,
sizeof(T), max_size(), static_cast<const void*>(&t), &destroy_array, &initialize_array_by );
923 void shrink_to_fit();
933 iterator
begin() {
return iterator(*
this,0);}
935 iterator
end() {
return iterator(*
this,
size());}
937 const_iterator
begin()
const {
return const_iterator(*
this,0);}
939 const_iterator
end()
const {
return const_iterator(*
this,
size());}
941 const_iterator
cbegin()
const {
return const_iterator(*
this,0);}
943 const_iterator
cend()
const {
return const_iterator(*
this,
size());}
945 reverse_iterator
rbegin() {
return reverse_iterator(
end());}
947 reverse_iterator
rend() {
return reverse_iterator(
begin());}
949 const_reverse_iterator
rbegin()
const {
return const_reverse_iterator(
end());}
951 const_reverse_iterator
rend()
const {
return const_reverse_iterator(
begin());}
953 const_reverse_iterator
crbegin()
const {
return const_reverse_iterator(
end());}
955 const_reverse_iterator
crend()
const {
return const_reverse_iterator(
begin());}
960 return (segment_value.template
pointer<T>())[0];
971 return internal_subscript(
size()-1 );
976 return internal_subscript(
size()-1 );
982 void assign(size_type n, const_reference t) {
984 internal_resize( n,
sizeof(T), max_size(), static_cast<const void*>(&t), &destroy_array, &initialize_array_by );
990 clear(); internal_assign_range( first, last,
static_cast<is_integer_tag<std::numeric_limits<I>::is_integer
> *>(0) );
993 #if __TBB_INITIALIZER_LISTS_PRESENT 994 void assign(std::initializer_list<T> init_list) {
996 clear(); internal_assign_iterators( init_list.begin(), init_list.end());
998 #endif //# __TBB_INITIALIZER_LISTS_PRESENT 1032 T& internal_subscript( size_type index )
const;
1035 T& internal_subscript_with_exceptions( size_type index )
const;
1039 internal_resize( n,
sizeof(T), max_size(), static_cast<const void*>(p), &destroy_array, p? &initialize_array_by : &initialize_array );
1054 internal_assign_n(static_cast<size_type>(first), &static_cast<T&>(last));
1059 internal_assign_iterators(first, last);
1063 void internal_assign_iterators(I first, I last);
1071 static void __TBB_EXPORTED_FUNC initialize_array_by(
void* begin,
const void* src, size_type n );
1076 #if __TBB_MOVE_IF_NOEXCEPT_PRESENT 1077 static void __TBB_EXPORTED_FUNC move_array_if_noexcept(
void* dst,
const void* src, size_type n );
1079 #endif //__TBB_MOVE_IF_NO_EXCEPT_PRESENT 1081 #if __TBB_CPP11_RVALUE_REF_PRESENT 1086 static void __TBB_EXPORTED_FUNC move_assign_array(
void* dst,
const void* src, size_type n );
1088 template<
typename Iterator>
1090 static void __TBB_EXPORTED_FUNC copy_range(
void* dst,
const void* p_type_erased_iterator, size_type n );
1106 static T*
as_pointer(
const void *src) {
return static_cast<T*
>(
const_cast<void *
>(src)); }
1109 : array(as_pointer(ptr)), n(ntrials), i(0) {}
1110 void init() {
for(; i < n; ++i)
new( &array[i] ) T(); }
1111 void init(
const void *src) {
for(; i < n; ++i)
new( &array[i] ) T(*as_const_pointer(src)); }
1112 void copy(
const void *src) {
for(; i < n; ++i)
new( &array[i] ) T(as_const_pointer(src)[i]); }
1113 void assign(
const void *src) {
for(; i < n; ++i) array[i] = as_const_pointer(src)[i]; }
1114 #if __TBB_CPP11_RVALUE_REF_PRESENT 1118 #if __TBB_MOVE_IF_NOEXCEPT_PRESENT 1119 void move_construct_if_noexcept(
const void *src) {
for(; i < n; ++i)
new( &array[i] ) T( std::move_if_noexcept(as_pointer(src)[i]) ); }
1120 #endif //__TBB_MOVE_IF_NOEXCEPT_PRESENT 1123 template<
class I>
void iterate(I &src) {
for(; i < n; ++i, ++src)
new( &array[i] ) T( *src ); }
1157 return iterator(v, k, ptr);
1162 #if __TBB_CPP17_DEDUCTION_GUIDES_PRESENT 1164 template<
typename I,
1165 typename T =
typename std::iterator_traits<I>::value_type,
1171 template<
typename T,
typename A1,
typename A2>
1176 template<
typename T,
typename A = cache_aligned_allocator<T>
1181 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 1182 #pragma warning (push) 1183 #pragma warning (disable: 4701) // potentially uninitialized local variable "old" 1185 template<
typename T,
class A>
1190 #if __TBB_MOVE_IF_NOEXCEPT_PRESENT 1191 &move_array_if_noexcept
1196 if(
internal_compact(
sizeof(T), &old, &destroy_array, copy_or_move_array ) )
1204 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 1205 #pragma warning (pop) 1206 #endif // warning 4701 is back 1208 template<
typename T,
class A>
1211 while( k > first_block ) {
1226 template<
typename T,
class A>
1230 size_type j = index;
1240 return (( segment_value.
pointer<T>()))[j];
1243 template<
typename T,
class A>
1247 size_type j = index;
1258 return (segment_value.
pointer<T>())[j];
1261 template<
typename T,
class A>
template<
class I>
1264 size_type n = std::distance(first, last);
1273 loop.iterate(first);
1276 else { ++k; sz <<= 1; }
1279 loop.iterate(first);
1282 template<
typename T,
class A>
1284 internal_loop_guide loop(n, begin); loop.init();
1287 template<
typename T,
class A>
1289 internal_loop_guide loop(n, begin); loop.init(src);
1292 template<
typename T,
class A>
1294 internal_loop_guide loop(n, dst); loop.copy(src);
1297 #if __TBB_CPP11_RVALUE_REF_PRESENT 1298 template<
typename T,
class A>
1300 internal_loop_guide loop(n, dst); loop.move_construct(src);
1302 template<
typename T,
class A>
1304 internal_loop_guide loop(n, dst); loop.move_assign(src);
1308 #if __TBB_MOVE_IF_NOEXCEPT_PRESENT 1309 template<
typename T,
class A>
1311 internal_loop_guide loop(n, dst); loop.move_construct_if_noexcept(src);
1313 #endif //__TBB_MOVE_IF_NOEXCEPT_PRESENT 1315 template<
typename T,
class A>
1316 template<
typename I>
1318 internal_loop_guide loop(n, dst);
1319 loop.iterate( *(static_cast<I*>(const_cast<void*>(p_type_erased_iterator))) );
1322 template<
typename T,
class A>
1324 internal_loop_guide loop(n, dst); loop.assign(src);
1327 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 1329 #pragma warning (push) 1330 #pragma warning (disable: 4189) 1332 template<
typename T,
class A>
1334 T* array =
static_cast<T*
>(
begin);
1335 for( size_type j=n; j>0; --j )
1338 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 1339 #pragma warning (pop) 1340 #endif // warning 4189 is back 1343 template<
typename T,
class A1,
class A2>
1347 if(a.
size() != b.
size())
return false;
1350 for(; i != a.
end(); ++i, ++j)
1351 if( !(*i == *j) )
return false;
1355 template<
typename T,
class A1,
class A2>
1357 {
return !(a == b); }
1359 template<
typename T,
class A1,
class A2>
1361 {
return (std::lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())); }
1363 template<
typename T,
class A1,
class A2>
1367 template<
typename T,
class A1,
class A2>
1369 {
return !(b < a); }
1371 template<
typename T,
class A1,
class A2>
1373 {
return !(a < b); }
1375 template<
typename T,
class A>
1381 #if defined(_MSC_VER) && !defined(__INTEL_COMPILER) 1382 #pragma warning (pop) 1383 #endif // warning 4267,4127 are back Internal structure for compact()
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp end
void shrink_to_fit()
Optimize memory usage and fragmentation.
static void __TBB_EXPORTED_FUNC assign_array(void *dst, const void *src, size_type n)
Assign (using operator=) n instances of T, starting at "dst" by assigning according element of src ar...
concurrent_vector(size_type n)
Construction with initial size specified by argument n.
Base class of concurrent vector implementation.
void clear()
Clear container while keeping memory allocated.
void internal_assign_n(size_type n, const_pointer p)
assign n items by copying t
const T & const_reference
friend bool operator==(segment_value_t const &lhs, segment_allocation_failed)
segment_t table[pointers_per_long_table]
size_type __TBB_EXPORTED_METHOD internal_grow_by(size_type delta, size_type element_size, internal_array_op2 init, const void *src)
size_type size() const
Return size of vector. It may include elements under construction.
void __TBB_EXPORTED_METHOD internal_throw_exception(size_type) const
Obsolete.
vector_iterator()
Default constructor.
generic_range_type(const generic_range_type< U > &r)
iterator end()
end iterator
void init(const void *src)
ptrdiff_t difference_type
static void __TBB_EXPORTED_FUNC move_array(void *dst, const void *src, size_type n)
Move-construct n instances of T, starting at "dst" by copying according element of src array...
void internal_assign_iterators(I first, I last)
assign by iterators
atomic< size_type > my_first_block
count of segments in the first block
const_reference at(size_type index) const
Get const reference to element at given index. Throws exceptions on errors.
bool operator==(const vector_iterator< Container, T > &i, const vector_iterator< Container, U > &j)
#define __TBB_ASSERT(predicate, comment)
No-op version of __TBB_ASSERT.
void internal_assign_range(I first, I last, is_integer_tag< true > *)
assign integer items by copying when arguments are treated as iterators. See C++ Standard 2003 23...
Specialization for atomic<void*>, for sake of not allowing arithmetic or operator->.
static bool is_first_element_in_segment(size_type element_index)
const_reference front() const
the first item const
const_reverse_iterator rbegin() const
reverse start const iterator
concurrent_vector(size_type n, const_reference t, const allocator_type &a=allocator_type())
Construction with initial size specified by argument n, initialization by copying of t...
#define __TBB_NOEXCEPT(expression)
iterator emplace_back(Args &&... args)
Push item, create item "in place" with provided arguments.
concurrent_vector(const concurrent_vector &vector, const allocator_type &a=allocator_type())
Copying constructor.
iterator return_iterator_and_dismiss()
segment_value_t(void *an_array)
concurrent_vector & operator=(const concurrent_vector &vector)
Assignment.
auto first(Container &c) -> decltype(begin(c))
static void __TBB_EXPORTED_FUNC destroy_array(void *begin, size_type n)
Destroy n instances of T, starting at "begin".
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp begin
size_type __TBB_EXPORTED_METHOD internal_capacity() const
const T & const_reference
std::random_access_iterator_tag iterator_category
static const T * as_const_pointer(const void *ptr)
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t new_size
segment_t my_storage[pointers_per_short_table]
embedded storage of segment pointers
Exception-aware helper class for filling a segment by exception-danger operators of user class...
friend class vector_iterator
Meets "allocator" requirements of ISO C++ Standard, Section 20.1.5.
generic_range_type< const_iterator > const_range_type
vector_iterator & operator--()
Pre decrement.
vector_iterator operator-(ptrdiff_t offset) const
vector_iterator & operator-=(ptrdiff_t offset)
concurrent_vector_base_v3 concurrent_vector_base
static void __TBB_EXPORTED_FUNC copy_range(void *dst, const void *p_type_erased_iterator, size_type n)
Copy-construct n instances of T, starting at "dst" by iterator range of [p_type_erased_iterator, p_type_erased_iterator+n).
friend bool operator==(segment_value_t const &lhs, segment_allocated)
void __TBB_EXPORTED_METHOD internal_swap(concurrent_vector_base_v3 &v)
void *__TBB_EXPORTED_METHOD internal_push_back(size_type element_size, size_type &index)
concurrent_vector(I first, I last, const allocator_type &a=allocator_type())
Construction with copying iteration range and given allocator instance.
vector_iterator & operator+=(ptrdiff_t offset)
concurrent_vector(const allocator_type &a=allocator_type())
Construct empty vector.
iterator push_back(T &&item)
Push item, move-aware.
const_reference back() const
the last item const
iterator begin()
start iterator
bool operator!=(const vector_iterator< Container, T > &i, const vector_iterator< Container, U > &j)
ptrdiff_t operator-(const vector_iterator< Container, T > &i, const vector_iterator< Container, U > &j)
iterator grow_by(size_type delta, const_reference t)
Grow by "delta" elements using copying constructor.
element_construction_guard g
void assign(size_type n, const_reference t)
assign n items by copying t item
concurrent_vector_base_v3()
void resize(size_type n, const_reference t)
Resize the vector, copy t for new elements. Not thread-safe.
const_iterator cend() const
end const iterator
segment_index_t __TBB_EXPORTED_METHOD internal_clear(internal_array_op1 destroy)
generic_range_type< iterator > range_type
push_back_helper(concurrent_vector &vector)
vector_iterator(const Container &vector, size_t index, void *ptr=0)
static segment_index_t segment_index_of(size_type index)
const_reverse_iterator crbegin() const
reverse start const iterator
reverse_iterator rend()
reverse end iterator
size_t my_index
Index into the vector.
vector_iterator< Container, T > operator+(ptrdiff_t offset, const vector_iterator< Container, T > &v)
void const char const char int ITT_FORMAT __itt_group_sync p
bool is_power_of_two_at_least(argument_integer_type arg, power2_integer_type power2)
A function to determine if arg is a power of 2 at least as big as another power of 2...
void store(segment_allocation_failed)
Value * my_item
Caches my_vector->internal_subscript(my_index)
static size_type segment_size(segment_index_t k)
atomic< size_type > my_early_size
Requested size of vector.
void move_construct(const void *src)
segment_index_t first_block
void throw_exception(exception_id eid)
Versionless convenience wrapper for throw_exception_v4()
bool operator>(const vector_iterator< Container, T > &i, const vector_iterator< Container, U > &j)
Concurrent vector container.
static void __TBB_EXPORTED_FUNC initialize_array_by(void *begin, const void *src, size_type n)
Copy-construct n instances of T, starting at "begin".
void assign(const void *src)
void __TBB_EXPORTED_METHOD internal_copy(const concurrent_vector_base_v3 &src, size_type element_size, internal_array_op2 copy)
auto last(Container &c) -> decltype(begin(c))
static void __TBB_EXPORTED_FUNC initialize_array(void *begin, const void *, size_type n)
Construct n instances of T, starting at "begin".
intptr_t __TBB_Log2(uintptr_t x)
void swap(segment_t &rhs)
Value & operator*() const
concurrent_vector & operator=(concurrent_vector &&other)
Move assignment.
#define __TBB_EXPORTED_METHOD
__TBB_EXPORTED_METHOD ~concurrent_vector_base_v3()
range_type range(size_t grainsize=1)
Get range for iterating with parallel algorithms.
void store(void *allocated_segment_pointer) __TBB_NOEXCEPT(true)
const internal::concurrent_vector_base_v3 & internal_vector_base() const
size_type capacity() const
Maximum size to which array can grow without allocating more memory. Concurrent allocations are not i...
segment_t(segment_t const &rhs)
void __TBB_EXPORTED_METHOD internal_grow_to_at_least(size_type new_size, size_type element_size, internal_array_op2 init, const void *src)
Deprecated entry point for backwards compatibility to TBB 2.1.
friend void enforce_segment_allocated(segment_value_t const &s, internal::exception_id exception=eid_bad_last_alloc)
static segment_index_t segment_base(segment_index_t k)
void internal_grow(size_type start, size_type finish, size_type element_size, internal_array_op2 init, const void *src)
const_iterator begin() const
start const iterator
void internal_free_segments(segment_t table[], segment_index_t k, segment_index_t first_block)
Free k segments from table.
void __TBB_EXPORTED_METHOD internal_assign(const concurrent_vector_base_v3 &src, size_type element_size, internal_array_op1 destroy, internal_array_op2 assign, internal_array_op2 copy)
void internal_assign_range(I first, I last, is_integer_tag< false > *)
inline proxy assign by iterators
static void __TBB_EXPORTED_FUNC move_assign_array(void *dst, const void *src, size_type n)
Move-assign (using operator=) n instances of T, starting at "dst" by assigning according element of s...
vector_iterator operator--(int)
Post decrement.
reference back()
the last item
void reserve(size_type n)
Allocate enough space to grow to size n without having to allocate more memory later.
void(__TBB_EXPORTED_FUNC * internal_array_op2)(void *dst, const void *src, size_type n)
An operation on n-element destination array and n-element source array.
friend void swap(segment_t &, segment_t &) __TBB_NOEXCEPT(true)
size_type max_size() const
Upper bound on argument to reserve.
T & internal_subscript_with_exceptions(size_type index) const
Get reference to element at given index with errors checks.
allocator_type get_allocator() const
return allocator object
const_reverse_iterator crend() const
reverse end const iterator
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain ITT_FORMAT p const __itt_domain __itt_string_handle unsigned long long value
internal_loop_guide(size_type ntrials, void *ptr)
concurrent_vector(const concurrent_vector< T, M > &vector, const allocator_type &a=allocator_type())
Copying constructor for vector with different allocator type.
internal::vector_iterator< concurrent_vector, const T > const_iterator
Meets requirements of a forward iterator for STL and a Value for a blocked_range.*/.
T & internal_subscript(size_type index) const
Get reference to element at given index.
const_iterator cbegin() const
start const iterator
void allocator_move_assignment(MyAlloc &my_allocator, OtherAlloc &other_allocator, traits_true_type)
iterator push_back(const_reference item)
Push item.
generic_range_type(generic_range_type &r, split)
ptrdiff_t difference_type
static void __TBB_EXPORTED_FUNC copy_array(void *dst, const void *src, size_type n)
Copy-construct n instances of T by copying single element pointed to by src, starting at "dst"...
allocator_base(const allocator_type &a=allocator_type())
std::reverse_iterator< iterator > reverse_iterator
void store(value_type value)
friend bool operator==(segment_value_t const &lhs, segment_not_used)
allocator_traits< Alloc >::template rebind_alloc< T >::other type
void assign(I first, I last)
assign range [first, last)
#define __TBB_EXPORTED_FUNC
void move(tbb_thread &t1, tbb_thread &t2)
A range over which to iterate.
vector_iterator & operator++()
Pre increment.
allocator_type my_allocator
const_reference operator[](size_type index) const
Get const reference to element at given index.
~concurrent_vector()
Clear and destroy vector.
pointer internal_push_back_result()
void *(* vector_allocator_ptr)(concurrent_vector_base_v3 &, size_t)
allocator function pointer
reference operator[](size_type index)
Get reference to element at given index.
void const char const char int ITT_FORMAT __itt_group_sync s
void move_assign(const void *src)
void allocator_swap(MyAlloc &my_allocator, OtherAlloc &other_allocator, traits_true_type)
void(__TBB_EXPORTED_FUNC * internal_array_op1)(void *begin, size_type n)
An operation on an n-element array starting at begin.
void __TBB_EXPORTED_METHOD internal_resize(size_type n, size_type element_size, size_type max_size, const void *src, internal_array_op1 destroy, internal_array_op2 init)
internal::allocator_base< T, A >::allocator_type allocator_type
iterator grow_to_at_least(size_type n)
Append minimal sequence of elements such that size()>=n.
Value * operator->() const
static T * as_pointer(const void *src)
bool empty() const
Return false if vector is not empty or has elements under construction at least.
reference front()
the first item
std::reverse_iterator< const_iterator > const_reverse_iterator
tbb::internal::allocator_rebind< A, T >::type allocator_type
iterator grow_by(std::initializer_list< T > init_list)
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t size
void *__TBB_EXPORTED_METHOD internal_compact(size_type element_size, void *table, internal_array_op1 destroy, internal_array_op2 copy)
static segment_index_t segment_base_index_of(segment_index_t &index)
generic_range_type(I begin_, I end_, size_t grainsize_=1)
segment_t & operator=(segment_t const &rhs)
internal::concurrent_vector_base_v3::size_type size_type
void resize(size_type n)
Resize the vector. Not thread-safe.
True/false function override helper.
ptrdiff_t difference_type
Container * my_vector
concurrent_vector over which we are iterating.
reference at(size_type index)
Get reference to element at given index. Throws exceptions on errors.
const_range_type range(size_t grainsize=1) const
Get const range for iterating with parallel algorithms.
bool operator>=(const vector_iterator< Container, T > &i, const vector_iterator< Container, U > &j)
friend bool operator!=(segment_value_t const &lhs, argument_type arg)
void handle_unconstructed_elements(T *array, size_t n_of_elements)
Exception helper function.
~element_construction_guard()
const_reverse_iterator rend() const
reverse end const iterator
reverse_iterator rbegin()
reverse start iterator
static void *const vector_allocation_error_flag
Bad allocation marker.
iterator grow_to_at_least(size_type n, const_reference t)
Dummy type that distinguishes splitting constructor from copy constructor.
iterator grow_by(I first, I last)
void swap(concurrent_vector &vector)
swap two instances
void store(segment_not_used)
element_construction_guard(pointer an_element)
internal::vector_iterator< concurrent_vector, T > iterator
size_type __TBB_EXPORTED_METHOD internal_grow_to_at_least_with_result(size_type new_size, size_type element_size, internal_array_op2 init, const void *src)
segment_value_t load() const
const_iterator end() const
end const iterator
concurrent_vector & operator=(const concurrent_vector< T, M > &vector)
Assignment for vector with different allocator type.
void copy(const void *src)
void __TBB_EXPORTED_METHOD internal_reserve(size_type n, size_type element_size, size_type max_size)
Number of slots for segment pointers inside the class.
vector_iterator operator++(int)
Post increment.
concurrent_vector(concurrent_vector &&source, const allocator_type &a)
iterator grow_by(size_type delta)
Grow by "delta" elements.
vector_iterator operator+(ptrdiff_t offset) const
static void * internal_allocator(internal::concurrent_vector_base_v3 &vb, size_t k)
Allocate k items.
vector_iterator(const vector_iterator< Container, typename Container::value_type > &other)
atomic< segment_t * > my_segment
Pointer to the segments table.
Value & operator[](ptrdiff_t k) const
concurrent_vector(concurrent_vector &&source)
Move constructor.