Creates a task that will complete successfully when all of the tasks supplied as arguments complete successfully.
template < typename _Iterator > auto when_all( _Iterator_Begin, _Iterator_End, const task_options& _TaskOptions = task_options() ) -> decltype (details::_WhenAllImpl<typename std::iterator_traits<_Iterator>::value_type::result_type, _Iterator>::_Perform(_TaskOptions, _Begin, _End));
The type of the input iterator.
The position of the first element in the range of elements to be combined into the resulting task.
The position of the first element beyond the range of elements to be combined into the resulting task.
A task that completes sucessfully when all of the input tasks have completed successfully. If the input tasks are of type T, the output of this function will be a task<std::vector<T>>. If the input tasks are of type void the output task will also be a task<void>.
when_all is a non-blocking function that produces a task as its result. Unlike task::wait, it is safe to call this function in a Windows 8.x Store app on the ASTA (Application STA) thread.
If one of the tasks is canceled or throws an exception, the returned task will complete early, in the canceled state, and the exception, if one is encoutered, will be thrown if you call task::get or task::wait on that task.
For more information, see Task Parallelism (Concurrency Runtime).