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;
   }

questionAnswers(1)

yourAnswerToTheQuestion