1
0
mirror of https://github.com/tearshark/librf.git synced 2024-10-01 15:57:07 +08:00
librf/tutorial/test_async_cb.cpp

106 lines
2.7 KiB
C++
Raw Normal View History

2020-03-26 17:26:39 +08:00
2017-09-24 14:01:30 +08:00
#include <chrono>
#include <iostream>
#include <string>
#include <thread>
#include "librf.h"
2020-02-18 11:32:20 +08:00
using namespace resumef;
2020-02-15 13:32:14 +08:00
template<class _Ctype>
2020-02-19 16:05:19 +08:00
static void callback_get_long(int64_t val, _Ctype&& cb)
2017-09-24 14:01:30 +08:00
{
using namespace std::chrono;
2020-02-15 13:32:14 +08:00
std::thread([val, cb = std::forward<_Ctype>(cb)]
{
std::this_thread::sleep_for(500ms);
2020-02-15 13:32:14 +08:00
cb(val * val);
}).detach();
}
2017-09-24 14:01:30 +08:00
2020-02-15 13:32:14 +08:00
//这种情况下,没有生成 frame-context因此并没有promise_type被内嵌在frame-context里
static future_t<int64_t> async_get_long(int64_t val)
2020-02-15 13:32:14 +08:00
{
awaitable_t<int64_t> awaitable;
2020-02-18 11:32:20 +08:00
callback_get_long(val, [awaitable](int64_t val)
2017-09-24 14:01:30 +08:00
{
2020-02-18 11:32:20 +08:00
awaitable.set_value(val);
2020-02-15 13:32:14 +08:00
});
2020-02-18 11:32:20 +08:00
return awaitable.get_future();
2017-09-24 14:01:30 +08:00
}
static future_t<int64_t> wait_get_long(int64_t val)
{
co_return co_await async_get_long(val);
}
2020-02-15 13:32:14 +08:00
//这种情况下,会生成对应的 frame-context一个promise_type被内嵌在frame-context里
static future_t<int64_t> resumable_get_long(int64_t val)
2017-09-24 14:01:30 +08:00
{
std::cout << val << std::endl;
val = co_await wait_get_long(val);
2017-09-24 14:01:30 +08:00
std::cout << val << std::endl;
val = co_await wait_get_long(val);
2017-09-24 14:01:30 +08:00
std::cout << val << std::endl;
val = co_await wait_get_long(val);
2017-09-24 14:01:30 +08:00
std::cout << val << std::endl;
co_return val;
2017-09-24 14:01:30 +08:00
}
static future_t<int64_t> loop_get_long(int64_t val)
2017-09-24 14:01:30 +08:00
{
std::cout << val << std::endl;
for (int i = 0; i < 5; ++i)
{
val = co_await async_get_long(val);
std::cout << val << std::endl;
}
co_return val;
2017-09-24 14:01:30 +08:00
}
static future_t<std::string&> async_get_string(std::string & ref_string)
{
awaitable_t<std::string&> awaitable;
callback_get_long(std::stoi(ref_string), [awaitable, &ref_string](int64_t val)
{
ref_string = std::to_string(val);
awaitable.set_value(ref_string);
});
return awaitable.get_future();
}
static future_t<std::string&> resumable_get_string(std::string& val)
{
std::cout << val << std::endl;
val = co_await async_get_string(val);
std::cout << val << std::endl;
val = co_await async_get_string(val);
std::cout << val << std::endl;
val = co_await async_get_string(val);
std::cout << val << std::endl;
co_return static_cast<std::string&>(val);
}
2017-09-24 14:01:30 +08:00
void resumable_main_cb()
{
//由于使用者可能不能明确的区分是resume function返回的awaitor还是awaitable function返回的awaitor
//导致均有可能加入到协程里去调度。
//所以,协程调度器应该需要能处理这种情况。
go async_get_long(3);
this_scheduler()->run_until_notask();
std::string ref_string{"2"};
go resumable_get_string(ref_string);
this_scheduler()->run_until_notask();
2017-09-24 14:01:30 +08:00
GO
2017-09-24 14:01:30 +08:00
{
auto val = co_await resumable_get_long(2);
std::cout << "GO:" << val << std::endl;
2017-09-24 14:01:30 +08:00
};
go loop_get_long(3);
this_scheduler()->run_until_notask();
2017-09-24 14:01:30 +08:00
}