- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
根据文档
the currently-running fiber retains control until it invokes some operation that passes control to the manager
我只能考虑一个操作 - boost::this_fiber::yield
这可能会导致从光纤到光纤的控制切换。但是,当我运行类似
bf::fiber([](){std::cout << "Bang!" << std::endl;}).detach();
bf::fiber([](){std::cout << "Bung!" << std::endl;}).detach();
我得到类似的输出
Bang!Bung!
\n
\n
这意味着控制在 <<
之间传递运营商从一根光纤到另一根光纤。这怎么可能发生?为什么?在 boost::fiber
的上下文中从光纤到光纤的控制传递的一般定义是什么?图书馆?
编辑001:没有代码就无法逃脱:
#include <boost/fiber/fiber.hpp>
#include <boost/fiber/mutex.hpp>
#include <boost/fiber/barrier.hpp>
#include <boost/fiber/algo/algorithm.hpp>
#include <boost/fiber/algo/work_stealing.hpp>
namespace bf = boost::fibers;
class GreenExecutor
{
std::thread worker;
bf::condition_variable_any cv;
bf::mutex mtx;
bf::barrier barrier;
public:
GreenExecutor() : barrier {2}
{
worker = std::thread([this] {
bf::use_scheduling_algorithm<bf::algo::work_stealing>(2);
// wait till all threads joining the work stealing have been registered
barrier.wait();
mtx.lock();
// suspend main-fiber from the worker thread
cv.wait(mtx);
mtx.unlock();
});
bf::use_scheduling_algorithm<bf::algo::work_stealing>(2);
// wait till all threads have been registered the scheduling algorithm
barrier.wait();
}
template<typename T>
void PostWork(T&& functor)
{
bf::fiber {std::move(functor)}.detach();
}
~GreenExecutor()
{
cv.notify_all();
worker.join();
}
};
int main()
{
GreenExecutor executor;
std::this_thread::sleep_for(std::chrono::seconds(1));
int i = 0;
for (auto j = 0ul; j < 10; ++j) {
executor.PostWork([idx {++i}]() {
auto res = pow(sqrt(sin(cos(tan(idx)))), M_1_PI);
std::cout << idx << " - " << res << std::endl;
});
}
while (true) {
boost::this_fiber::yield();
}
return 0;
}
输出
2 - 1 - -nan
0.503334 3 - 4 - 0.861055
0.971884 5 - 6 - 0.968536
-nan 7 - 8 - 0.921959
0.9580699
- 10 - 0.948075
0.961811
最佳答案
好吧,我错过了几件事,首先,我的结论是基于对 boost::fiber
中的东西是如何工作的误解。
问题中提到的构造函数中的行 bf::use_scheduling_algorithm<bf::algo::work_stealing>(2);
在 GreenExecutor
所在的线程中安装调度程序实例已创建(在主线程中),因此,在启动两个 worker 时 fiber
s 我实际上启动了两个将要处理提交的线程 fiber
s 反过来会处理这些 fibers
异步混合 std::cout
输出。没有魔法,一切都按预期工作,boost::fiber::yield
仍然是将控制从一根光纤传递到另一根光纤的唯一选择
关于c++ - boost::fiber 调度 - 何时以及如何,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51017582/
我正在学习 ruby.. 并且我是编程新手 fiber = Fiber.new do |first| second = Fiber.yield first + 2 end puts fiber
如何使用 C++ boost 停止(中断)光纤? 例如 fiber.stop() 我如何使用 c+ boost 执行 fiber join(time)(默认 api 不接受最长等待时间)? 例如: f
Fibers被定义为轻量级线程,线程具有优先级,因为它们是抢占式调度的。然而,由于纤维是合作的,它们是否也有优先级? 最佳答案 不,它们本质上没有优先级,因为在协作式多任务处理中,上下文切换目标总是由
我很难理解我应该在我正在处理的代码中的何处实现wrapAsync/bindEnvironment。我正在使用 http/knox 调用 url 并将其上传到我的 S3 存储桶,该存储桶可以正常工作,但
meteor 纤维“同步”模式让我发疯。这是一个简单的代码示例: var feedsData = feeds.fetch(); // [{_id: "1234"}, {_id: "6789", url
void helloFiber(boost::fibers::future &f) { cout pm; boost::fibers::future ft = pm.get_futu
我想知道如何暂停 ruby 中的 Root Fiber(如果可能)。 我有这个 Sinatra 应用程序,我正在使用 EventMachine 对外部 API 进行异步调用。在 API 响应我之前
大家好,我是 polarisxu。 Middleware(中间件) 是一个 Web 框架重要的组成部分,通过这种模式,可以方便的扩展框架的功能。目前 Go Web 框架都提供了 Middlew
我想在 ZIO Fibers 上使用组合器 orElse。 从文档: 如果第一个纤维成功,则合成的纤维将成功,其结果;否则,组成的光纤将以第二条光纤的退出值完成(无论成功或失败)。 import zi
我有以下 ZIO 程序,其中包含两个永久运行的进程: for { .. numberProvider <- numberProvider(queue).fork //
我正在使用 Fibers 来处理不同代码块之间的调度,事实证明这比尝试管理线程要简单得多,因为我的用例相当简单(并且一次只涉及运行一个脚本)。不幸的是,我需要偶尔“杀死”Fiber 的能力,但 Fib
我很难学习 Fibers\coroutines 背后的想法和 Crystal 中的实现。 我希望这是问这个问题的正确地方,我会完全接受“不在这里”的答案:) 这是我在 Ruby 中处理多线程的常用方法
我负责一个 Windows 应用程序,该应用程序加载用 C++ 编写的插件“脚本”dll。 该应用程序公开了一个基于 Win32 纤维的 API,以允许插件 dll 中的 C++“脚本”使用“yiel
部署到其他服务器后,捆绑的 node.fibers 无法加载,并出现以下错误: /home/ec2-user/bundle/server/node_modules/fibers/fibers.js:1
我正在尝试为 Fabrikam Fiber 调用中心下载 Asp.Net 应用程序。 Larry guger 在他关于 http://channel9.msdn.com/Events/TechEd/N
我已成功使用本地上下文通过自定义中间件设置数据库查询结果。我试图了解如何对用户进行身份验证,然后从数据库中提取其详细信息并将其注入(inject)上下文中。这已经完成了。 路由上 final方法上的本
当我收到一个包含要上传到服务器的文件列表的post 请求时,如果我知道它的名称,我可以获取特定文件 c.FormFile("文件名") 但是,如果事先不知道文件名,我该如何遍历该列表中的文件呢?我没有
当我收到一个包含要上传到服务器的文件列表的post 请求时,如果我知道它的名称,我可以获取特定文件 c.FormFile("文件名") 但是,如果事先不知道文件名,我该如何遍历该列表中的文件呢?我没有
我正在使用类星体光纤来监听和处理 QueueObjectChannel 上的消息。我不确定应该使用什么对象作为光纤之间的消息队列。我遇到的问题是我不明白应该将什么传递到 QueueObjectChan
我有以下函数,用作 Windows Fiber 的入口点。 void foo(void*) { for(int i =0; i < 10; ++i) { doStuff(); } } 现在我在
我是一名优秀的程序员,十分优秀!