- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
结构任务修改自https://github.com/Quuxplusone/coro/blob/master/include/coro/gor_task.h .我只是更改suspend_always
in Line 18暂停_never。
// test.cpp
#include <exception>
#include <experimental/coroutine>
#include <variant>
template<class T>
struct task {
struct promise_type {
std::variant<std::monostate, T, std::exception_ptr> result_;
std::experimental::coroutine_handle<void> waiter_;
task get_return_object() { return task(this); }
auto initial_suspend() { return std::experimental::suspend_never{}; } // Originally suspend_always
auto final_suspend() {
struct Awaiter {
promise_type *me_;
bool await_ready() { return false; }
void await_suspend(std::experimental::coroutine_handle<void> caller) {
me_->waiter_.resume();
}
void await_resume() {}
};
return Awaiter{this};
}
template<class U>
void return_value(U&& u) {
result_.template emplace<1>(static_cast<U&&>(u));
}
void unhandled_exception() {
result_.template emplace<2>(std::current_exception());
}
};
bool await_ready() { return false; }
void await_suspend(std::experimental::coroutine_handle<void> caller) {
coro_.promise().waiter_ = caller;
coro_.resume();
}
T await_resume() {
if (coro_.promise().result_.index() == 2) {
std::rethrow_exception(std::get<2>(coro_.promise().result_));
}
return std::get<1>(coro_.promise().result_);
}
~task() {
coro_.destroy();
}
private:
using handle_t = std::experimental::coroutine_handle<promise_type>;
task(promise_type *p) : coro_(handle_t::from_promise(*p)) {}
handle_t coro_;
};
#include <stdio.h>
task<int> f2() {
puts("enter f2");
co_return 1;
}
task<int> f1() {
puts("enter f1");
int a = co_await f2();
printf("f2 return: %d\n", a);
co_return a;
}
int main() {
f1();
}
$ clang++ -fcoroutines-ts -std=c++17 -stdlib=libc++ -lc++ -lc++abi test.cpp -o test
$ ./test
enter f1
enter f2
fish: './test' terminated by signal SIGSEGV (Address boundary error)
因为没有 co_await
,我希望 f2 return: 1
应该被打印并且程序应该正常退出,但它因段错误而崩溃。为什么以及如何解决此问题?
最佳答案
当协程函数执行 co_await
时,它会停止该函数的执行并将该执行的恢复安排给其他人。这个“其他人”最终取决于被 co_await
处理的表达式、协程函数的 promise 类型以及协程返回的 future 类型。
那么让我们看看这里的控制流。
f2
被调用。它执行,然后通过 co_return
终止。这意味着 f2
的协程句柄是完整的。这也意味着将调用 promise 类型的 final_suspend
。好吧,协程机制期望 final_suspend
将返回一个等待类型,您的 task::promise
提供了它。
除了... task::promise::waiter_
未初始化。这是因为只有await_suspend
给waiter_
赋值。还没有人对 f2
的返回值进行 co_await
编辑。因此,在此之前,waiter_
没有值。
因此,当 f2
被调用时,您尝试继续一个充其量为 nullptr
的协程句柄,从而导致崩溃。
如果 final_suspend
的 Awaiter
类型首先检查 waiter_
是否为 nullptr
会更有意义(这意味着还没有人在等待协程)如果是,则从 await_ready
返回 true
。
关于C++ 协程 : call a coroutine function without co_await,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59434882/
import kotlinx.coroutines.* fun log(msg: String) = println("[${Thread.currentThread().name}] $msg")
我有一个长计算的外部库。这个库就是一切,但在过早停止方面是合作的。它被包装并在一个协程中启动。 我想从调用方终止进程。协程取消是合作的,所以它不起作用。有没有办法突然终止协程? 最佳答案 非挂起的协程
我是 Kotlin/Coroutines 的新手,我注意到两种不同的使用方式 CoroutineScope . 选项 1 如下,在任何函数中: CoroutineScope(Dispatchers.D
我对协同例程比较陌生,我正在尝试获取 Launch 协同例程将完成的行为: launch(UI) { val v1 = someDeferredType val v2 = v1.a
文档说: @asyncio.coroutine Decorator to mark generator-based coroutines. This enables the generator use
我在 kotest 中使用了 Funspec 测试风格,我得到了一个由框架自动注入(inject)的 coroutineScope,如下所示。 class MyTestSpec: FunSpec()
我想尝试从一个courtine 中暂停主线程。几个问题,但首先让我向您展示我正在使用的代码块作为测试: class MainActivity : Activity(), CoroutineScope
我不确定我是否理解 purescript-coroutines 中有一个 connect 和一个 pullFrom 函数的原因。 ,以及何时使用它们。看看这些类型,它们似乎已经习惯了改变“通信方向”(
我在不同的类(class_A、class_B)中有 2 个协程(co_A、co_B)由调度程序定期调用。在执行期间的某个时候,co_B 需要一个 co_A 在其运行期间正在计算的结果。 我想做的是这样
在 document , 如果方法也用@gen.coroutine 修饰,则不需要@web.asynchronous。像这样 @web.asynchronous @gen.coroutine def
目前在 pzmq 中有多种方法来实现文档中提到的异步 IO 循环。 http://pyzmq.readthedocs.io/en/latest/api/index.html 从纯性能的角度来看,文档中
看来我误解了当有许多套接字被打开时 Windows 如何在 TIME_WAIT 中处理套接字。如果在 TIME_WAIT 中挂出太多,它只会出错。 Linux 清理旧连接并成功(至少在我的盒子上,不确
我正在尝试对我使用 Kotlin 协程制作的 Presenter 进行单元测试,这也是我第一次使用 Mockito 每当我尝试运行单元测试时,它在协程中第一次尝试对我的 View 执行任何操作时都会收
我注意到 Boost.Coroutine2 for C++ 中删除了对对称协程的支持,所以我想了解 - 两者之间有什么区别? 最佳答案 Ana Lúcia de Moura 和 Roberto Ier
在Linux System Programming, 2nd Edition书中,协程与纤维之间的差异解释如下: 协程和纤维提供了比线程更轻的执行单元(前者是编程语言结构时的名称,后者是系统结构时的名
此示例已在另一个问题中用于说明如何使用协程来编写视频游戏中的过场动画: bob.walkto(jane) bob.lookat(jane) bob.say("How are you?") wait(2
我正在寻找实现 FSM 的方法,这导致我第一次遇到协程。 我看到了几个示例(here、here 和 here),它们暗示状态机可以由单个协程实现。然而,我注意到所有这些机器的共同点是,不包括循环,它们
浅说c/c++ coroutine 从上面我们可以得到关于协程的几个关键信息, 1.打破传统(regular)函数调用的限制。 2.stack
我试图从ViewModel异步获取所有可启动的已安装应用程序。 这是我的ViewModel类的样子: class AppInstalledViewModel(application: Applicat
如何在kotlin中像多线程一样进行多次启动 我想让 first second 永远同时工作!! 喜欢这段代码... runBlocking { // first launch{
我是一名优秀的程序员,十分优秀!