Espacios de nombres
Variantes
Acciones

Archivo de encabezado de la biblioteca estándar <future>

De cppreference.com
< cpp‎ | header
 
 
Archivos de encabezado de la biblioteca estándar
 

Este archivo de encabezado es parte de la biblioteca de soporte de hilos.

Contenido

Clases

(C++11)
Almacena un valor para recuperación asíncrona.
(plantilla de clase)[editar]
Empaqueta una función para almacenar su valor de retorno para la recuperación asíncrona.
(plantilla de clase)[editar]
(C++11)
Espera a un valor que se establece asíncronamente.
(plantilla de clase)[editar]
Espera a un valor (posiblemente referenciado por otros futuros) que se ha establecido asíncronamente.
(plantilla de clase)[editar]
(C++11)
Especifica la política de lanzamiento de std::async.
(enum)[editar]
Especifica los resultados de esperas cronometradas realizadas en std::future y std::shared_future.
(enum)[editar]
Informa de un error relacionado con futuros o promesas.
(clase)[editar]
Identifica los códigos de error del futuro.
(enum)[editar]
Especializa el rasgo de tipo std::uses_allocator
(especialización de plantilla de clase)[editar]
Especializa al rasgo de tipo std::uses_allocator
(especialización de plantilla de clase)[editar]

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)[editar]
Identifica la categoría de error del futuro.
(función)[editar]
Especializa el algoritmo std::swap.
(plantilla de función)[editar]
Especializa al algoritmo std::swap.
(plantilla de función)[editar]

[editar]Sinopsis

namespace std {enumclass 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 */};   enumclass launch :/* sin especificar */{ async =/* sin especificar */, deferred =/* sin especificar */, /* definido por la implementación */};   enumclass 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 definirtemplate<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()constnoexcept;constchar* what()constnoexcept;   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 resultadovoid set_value(/* véase descripción */);void set_exception(exception_ptr p);   // establecer el resultado con notificación diferidavoid 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 estadobool valid()constnoexcept;   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::shared_future

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 estadobool valid()constnoexcept;   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()constnoexcept;   // recuperación del resultado future<R> get_future();   // ejecuciónvoid 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;}
close