- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在基于 windows io 完成端口的异步套接字类中添加对协程 ts 的支持。
如果没有协程,io 可以这样完成:
sock.async_write(io::buffer(somebuff), [](auto&& ... args){ /* in handler */ });
sock.async_write(std::vector<io::const_buffer>{ ... }, [](auto&& ... args){ /* in handler */ })
operator co_await
将提交操作,所以我需要在等待中缓存参数以避免使用破坏的临时文件:
awaitable coro_write(const io::const_buffer& buff)
{
return awaitable{ *this, buff };
}
awaitable coro_write(const std::vector<io::const_buffer>& buffs)
{
return awaitable{ *this, buffs };
}
A typical generator's yield_value would store (copy/move or just store the address of, since the argument's lifetime crosses the suspension point inside the co_await) its argument into the generator object and return std::suspend_always, transferring control to the caller/resumer.
co_yield
表达式等价于:
co_await promise.yield_value(expr)
co_await sock.coro_write(expr)
yield_value
并稍后通过
generator::iterator::operator *()
检索到它在协程暂停后的调用者站点中:
struct promise_type {
_Ty const* _CurrentValue;
auto yield_value(_Ty const& _Value) {
_CurrentValue = _STD addressof(_Value);
return suspend_always{};
}
}
struct iterator {
_NODISCARD reference operator*() const {
return *_Coro.promise()._CurrentValue;
}
_NODISCARD pointer operator->() const {
return _Coro.promise()._CurrentValue;
}
}
co_await
一起使用的等待程序。在协程恢复或销毁之前也将保持有效,对吗?或者这是
yield_value
专用的在 promise 类型中?
最佳答案
使用 Visual Studio 2019 16.4.4 进行测试,可以正常工作。事实上,传递的参数和转换后的参数也保持有效并且不会被破坏,直到 await_resume
返回或 await_suspend
由于抛出的异常或指示无意挂起 coroutine 的返回值而未挂起。
这就是我所做的:
1 - 为缓冲区类型创建的析构函数如下:
~const_buffer()
{
std::cout << __FUNCSIG__ << std::endl;
}
~mutable_buffer()
{
std::cout << __FUNCSIG__ << std::endl;
}
// mutable to const conversion
operator const_buffer() const noexcept { return { data_, size_ }; }
issue_coro_op
调用的
await_suspend
的末尾我放了类似的打印:
void issue_coro_op(awaitable& a)
{
// use the awaitable to issue the op
std::cout << "~ " << __FUNCSIG__ << std::endl;
}
await_resume
的末尾我放了一个类似的打印
awaitable coro_read(const io::mutable_buffer& buff, transfer_flags);
awaitable coro_write(const io::const_buffer& buff, transfer_flags);
template </**/>
awaitable::awaitable(const io::mutable_buffer& buff) { /*store in ptr*/ }
template </**/>
awaitale::awaitable(const io::const_buffer& buff) { /*store in ptr*/ }
io::task<> run_session(tcp::async_socket sock)
{
char buff[1024];
string server_msg;
try
{
for (;;)
{
auto n = co_await sock.coro_read(io::buffer(buff), transfer_flags::unspecified);
if (buff[n - 1] == '\n')
--n;
cout << ">> " << string_view{ buff, n } << endl;
server_msg = fmt::format("{{ server message : {} }}\n", string_view{ buff, n });
n = co_await sock.coro_write(io::buffer(server_msg), transfer_flags::unspecified);
}
}
catch (std::exception & ex)
{
cout << "[!] a client has disconnected : " << ex.what() << endl;
}
}
nc localhost 4567
some message
{ server message : some message }
issue_coro_op -> read
await_resume -> read
~mutable_buffer -> read
>> some message
issue_coro_op -> write
await_resume -> write
~const_buffer -> write
~mutable_buffer -> write
io::buffer
返回
io::mutable_buffer
,它在写操作中被转换为
io::const_buffer
并且两者在恢复之前保持有效,然后它们以相反的顺序被破坏
关于c++ - 传递给返回 awaitable 的函数的临时对象在使用 co_await 暂停点后是否仍然有效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60737075/
每次我尝试构建(执行完整的 Clean,然后构建)时,我都会在 Eclipse 的问题部分下弹出此错误消息。项目本身旁边还显示一个错误。 我已经尝试了同一问题的其他解决方案中包含的所有内容: 删除项目
我收到以下错误(注意:我使用的是 Netbeans): java.sql.SQLException: No suitable driver found for jdbc:derby://localho
例如 //somewhere struct IFace; struct Base { Base(IFace* iface): f(iface) { //wi
我试图通过 stringstream 将 double 变成字符串,但它不起作用。 std::string MatlabPlotter::getTimeVector( unsigned int xve
我正在尝试使用 AudioKit 框架中的音序器播放音频文件。 AudioKit.output = sampler AudioKit.start() sampler.enableMID
昨天我问了一个关于插入 Heroku 的问题。它不工作,然后突然开始工作。我什么都没改变。现在在一个新的应用程序上,我遇到了完全相同的问题。我决定包含我的整个 Gemfile,希望我可以继续没有这种令
我知道,这个topic已经是discussed许多times,所以直截了当。 这是ItemsSource的TabControl: Tabs = new ObservableCollection {
我有一个更新对象的函数,问题是当我从更新表单字段返回到详细 View 时,它初始化旧对象而不是更新后的对象。 我想在 CarService 而不是 app.js 中填充汽车列表 这是我的汽车服务:
在 resolution comments错误报告 12266 (“套接字连接错误导致资源泄漏”),Robert Ehteshamzadeh 写道 TClientSocket is deprecate
我最初发布了一个问题 here 我发现 JTextField 仅在 JScrollPane 存在时才调整大小。换句话说,我可以根据需要最小化和最大化它,直到出现滚动条(因为文本太多,无法放入窗口)。之
我读过关于 postion:absolute 的问题并尝试了几乎所有可能的解决方案。包括相对定位 div,将它们包装在相对定位的父级中等等,但它没有帮助。 我正在绘制一个表格,然后我将 div 放入其
我在这里发起了一个话题document.getElementById not working但看起来即使提出的建议都是有效的,我仍然有问题。 我有几个复选框。当我在这里查看页面源代码时,有。 docu
我正在做一些阅读,试图更好地理解按位运算符,然后偶然发现了 a helpful old blog post from 2012 ,其中指出 - 在随机正整数 x 的奇数测试中 - 在作者的计算机上评估
我正在尝试在 Eclipse Neon 中使用 aspectj 创建一个示例 maven 项目。然而,方面并没有编织/工作(参见下面的输出)。我尝试寻找很多原因和解决方案,但没有一个有效(请参阅下面的
无论我如何配置我的 appsettings.json 和 appsettings.Development.json,除非我手动添加 ConfigureLogging,否则我无法在信息消息下方记录任何内
我正在尝试使用 JQuery .get() 方法和 JavaScript for 循环来处理来自外部文件的一些数据。我已经在 stackoverflow 上阅读了有关闭包和回调返回值的内容几个小时,但
我正在使用 PHP 5.6 并且要打印一些东西,我必须编辑 php.ini 并包含 php_printer.dll 文件。但是 PHP 5.6 没有.dll 文件。 我要解决的问题: 我想将凭证打印机
我目前正在调试一个包含内存泄漏的大(非常大!)C# 应用程序。它主要使用 Winforms 作为 GUI,尽管一些控件是在 WPF 中制作的,并由 ElementHost 托管。直到现在,我发现许多内
[已解决] 看来 PHP MYADMIN 变量成功了。我将 wait_timeout 设置为 30 ,并将 Lock_wait_timeout 设置为 50 花了将近 6 个小时才恢复稳定,包括几次重
我读过几个关于该主题的讨论,有人说 qmake < 3.0 不正确支持该指令。我刚刚为 g++-64 重新安装了 Qt 5.9.1,但问题仍然存在。此外,我尝试过各种 mkspecs/xxx/xxx.
我是一名优秀的程序员,十分优秀!