boost :: future e continuations - conjunto de valores, mas o futuro ainda bloqueia
Estou tentando fazer a seguinte continuação funcionar - masf.get()
blocos. O que há de errado?
#include <iostream>
#define BOOST_THREAD_PROVIDES_FUTURE
#define BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
#include <boost/thread/future.hpp>
struct Foo {
boost::future<int> start() {
return p.get_future();
}
void finish() {
p.set_value(23);
}
boost::promise<int> p;
};
int main () {
Foo foo;
foo.start().then([](boost::future<int> f) {
std::cout << "done:" << std::endl;
std::cout << f.get() << std::endl;
});
foo.finish();
}
Ele imprimirá o"done:"
, então o futuro dispara, mas então "aguenta"f.get()
.. Eu estou perdido.
Construir:
clang++ -o test8 -std=c++11 -stdlib=libc++ -lboost_thread -lboost_system \
-I/home/oberstet/boost_1_55_0 -L/home/oberstet/boost_1_55_0/stage/lib \
test8.cpp
ATUALIZAR: A seguinte alteração de código fará o exemplo funcionar - mas por quê? Desde af2
não é usado de qualquer maneira. Intrigado novamente.
boost::future<void> f2 = foo.start().then([](boost::future<int> f) {
std::cout << "done:" << std::endl;
std::cout << f.get() << std::endl;
});
ATUALIZAÇÃO 2: A seguir, adicionando uma política de inicializaçãolaunch::deferred
, também funcionará:
foo.start().then(boost::launch::deferred, [](boost::future<int> f) {
std::cout << "done:" << std::endl;
std::cout << f.get() << std::endl;
});
e isso também:
boost::future<int> start() {
boost::future<int> f = p.get_future();
f.set_deferred();
return f;
}