Archivo de encabezado de la biblioteca estándar <future>
De cppreference.com
Este archivo de encabezado es parte de la biblioteca de soporte de hilos.
Clases | ||
(C++11) |
Almacena un valor para recuperación asíncrona. (plantilla de clase) | |
(C++11) |
Empaqueta una función para almacenar su valor de retorno para la recuperación asíncrona. (plantilla de clase) | |
(C++11) |
Espera a un valor que se establece asíncronamente. (plantilla de clase) | |
(C++11) |
Espera a un valor (posiblemente referenciado por otros futuros) que se ha establecido asíncronamente. (plantilla de clase) | |
(C++11) |
Especifica la política de lanzamiento de std::async. (enum) | |
(C++11) |
Especifica los resultados de esperas cronometradas realizadas en std::future y std::shared_future. (enum) | |
(C++11) |
Informa de un error relacionado con futuros o promesas. (clase) | |
(C++11) |
Identifica los códigos de error del futuro. (enum) | |
Especializa el rasgo de tipo std::uses_allocator (especialización de plantilla de clase) | ||
Especializa al rasgo de tipo std::uses_allocator (especialización de plantilla de clase) | ||
Funciones | ||
(C++11) |
Ejecuta una función asíncronamente (posiblemente en un nuevo hilo) y devuelve un std::future que contendrá el resultado. (plantilla de función) | |
(C++11) |
Identifica la categoría de error del futuro. (función) | |
(C++11) |
Especializa el algoritmo std::swap. (plantilla de función) | |
Especializa al algoritmo std::swap. (plantilla de función) |
[editar] Sinopsis
namespace std { enum class future_errc { broken_promise = /* definido por la implementación */, future_already_retrieved = /* definido por la implementación */, promise_already_satisfied = /* definido por la implementación */, no_state = /* definido por la implementación */ }; enum class launch : /* sin especificar */ { async = /* sin especificar */, deferred = /* sin especificar */, /* definido por la implementación */ }; enum class future_status { ready, timeout, deferred }; template<> struct is_error_code_enum<future_errc> : public true_type { }; error_code make_error_code(future_errc e) noexcept; error_condition make_error_condition(future_errc e) noexcept; const error_category& future_category() noexcept; class future_error; template<class R> class promise; template<class R> class promise<R&>; template<> class promise<void>; template<class R> void swap(promise<R>& x, promise<R>& y) noexcept; template<class R, class Alloc> struct uses_allocator<promise<R>, Alloc>; template<class R> class future; template<class R> class future<R&>; template<> class future<void>; template<class R> class shared_future; template<class R> class shared_future<R&>; template<> class shared_future<void>; template<class> class packaged_task; // sin definir template<class R, class... ArgTypes> class packaged_task<R(ArgTypes...)>; template<class R, class... ArgTypes> void swap(packaged_task<R(ArgTypes...)>&, packaged_task<R(ArgTypes...)>&) noexcept; template<class F, class... Args> [[nodiscard]] future<invoke_result_t<decay_t<F>, decay_t<Args>...>> async(F&& f, Args&&... args); template<class F, class... Args> [[nodiscard]] future<invoke_result_t<decay_t<F>, decay_t<Args>...>> async(launch policy, F&& f, Args&&... args); }
[editar] Clase std::future_error
namespace std { class future_error : public logic_error { public: explicit future_error(future_errc e); const error_code& code() const noexcept; const char* what() const noexcept; private: error_code ec_; // solo exposición }; }
[editar] Plantilla de clase std::promise
namespace std { template<class R> class promise { public: promise(); template<class Allocator> promise(allocator_arg_t, const Allocator& a); promise(promise&& rhs) noexcept; promise(const promise&) = delete; ~promise(); // asignación promise& operator=(promise&& rhs) noexcept; promise& operator=(const promise&) = delete; void swap(promise& other) noexcept; // recuperar el resultado future<R> get_future(); // establecer el resultado void set_value(/* véase descripción */); void set_exception(exception_ptr p); // establecer el resultado con notificación diferida void set_value_at_thread_exit(/* véase descripción */); void set_exception_at_thread_exit(exception_ptr p); }; template<class R> void swap(promise<R>& x, promise<R>& y) noexcept; template<class R, class Alloc> struct uses_allocator<promise<R>, Alloc>; }
[editar] Plantilla de clase std::future
namespace std { template<class R> class future { public: future() noexcept; future(future&&) noexcept; future(const future&) = delete; ~future(); future& operator=(const future&) = delete; future& operator=(future&&) noexcept; shared_future<R> share() noexcept; // recuperar el resultado /* véase descripción */ get(); // funciones para comprobar estado bool valid() const noexcept; void wait() const; template<class Rep, class Period> future_status wait_for(const chrono::duration<Rep, Period>& rel_time) const; template<class Clock, class Duration> future_status wait_until(const chrono::time_point<Clock, Duration>& abs_time) const; }; }
[editar]
namespace std { template<class R> class shared_future { public: shared_future() noexcept; shared_future(const shared_future& rhs) noexcept; shared_future(future<R>&&) noexcept; shared_future(shared_future&& rhs) noexcept; ~shared_future(); shared_future& operator=(const shared_future& rhs) noexcept; shared_future& operator=(shared_future&& rhs) noexcept; // recuperar el valor /* véase descripción */ get() const; // funciones para comprobar estado bool valid() const noexcept; void wait() const; template<class Rep, class Period> future_status wait_for(const chrono::duration<Rep, Period>& rel_time) const; template<class Clock, class Duration> future_status wait_until(const chrono::time_point<Clock, Duration>& abs_time) const; }; }
[editar] Plantilla de clase std::packaged_task
namespace std { template<class> class packaged_task; // sin definir template<class R, class... ArgTypes> class packaged_task<R(ArgTypes...)> { public: // construcción y destrucción packaged_task() noexcept; template<class F> explicit packaged_task(F&& f); ~packaged_task(); // no se permite copia packaged_task(const packaged_task&) = delete; packaged_task& operator=(const packaged_task&) = delete; // soporte de semántica de movimiento packaged_task(packaged_task&& rhs) noexcept; packaged_task& operator=(packaged_task&& rhs) noexcept; void swap(packaged_task& other) noexcept; bool valid() const noexcept; // recuperación del resultado future<R> get_future(); // ejecución void operator()(ArgTypes... ); void make_ready_at_thread_exit(ArgTypes...); void reset(); }; template<class R, class... ArgTypes> void swap(packaged_task<R(ArgTypes...)>& x, packaged_task<R(ArgTypes...)>& y) noexcept; }