6

为了在 boost 中尝试新的协程功能,我创建了以下程序:

#include <boost/coroutine/all.hpp>
#include <string>
#include <vector>


typedef boost::coroutines::coroutine<int(char)> coroutine_t;


void f(coroutine_t::caller_type & ca)
{
    std::vector<int> vec = {1, 2, 3};
    for (int i : vec)
    {
        char c = ca.get();
        std::cout << "c: " << c << std::endl;
        ca(i);
    }
}

int main()
{
    coroutine_t cr(f);
    std::string str("abc");
    for (char c : str)
    {
        std::cout << c << std::flush;
        cr(c);
        int n = cr.get();
        std::cout << n << std::endl;        
    }
}

该代码基于docs 中的示例代码

我的构建命令如下:

$ g++ -std=c++11 -o test -I/usr/local/include -L/usr/local/lib main.cpp /usr/local/lib/libboost_context.a

输出:

$ ./test
test: /usr/local/include/boost/coroutine/detail/coroutine_get.hpp:43: typename boost::coroutines::detail::param<Result>::type boost::coroutines::detail::coroutine_get<D, Result, arity>::get() const [with D = boost::coroutines::coroutine<char(int), 1>; Result = char; int arity = 1; typename boost::coroutines::detail::param<Result>::type = char]: Assertion `static_cast< D const* >( this)->impl_->result_' failed.
Aborted (core dumped)

由于断言失败,程序被中止。你能帮我找出我的代码中的错误吗?

4

1 回答 1

2

我相信您需要ca()在函数的开头添加一个调用f

从升压文档:

执行控制在构造时转移到协程(进入协程函数) - 当控制应该返回到原始调用例程时,在 boost 类型的第一个参数上调用 boost::coroutines::coroutine<>::operator(): :coroutines::coroutine<>::caller_type 在协程函数中。

于 2013-02-05T15:12:15.020 回答