是并发的结果::何时返回向量FIFO?
-
21-12-2019 - |
题
解决方案
我也无法从Microsoft文档中找到。制作了一个简单的测试,线程以某种方式终止随机顺序,但最终输出是1,2,3,4,5。您可以创建具有不同随机负载的100个线程,我认为结果不会改变。结论是您可以安全地使用此假设。
#include <ppltasks.h>
#include <array>
#include <iostream>
using namespace concurrency;
using namespace std;
int wmain()
{
// Start multiple tasks.
array<task<int>, 5> tasks =
{
create_task([]() -> int {
for (int i = 0; i < 100; i++) {
wcout << "thread 1: " << i << endl;
}
return 1;
}),
create_task([]() -> int {
for (int i = 0; i < 100; i++) {
wcout << "thread 2: " << i << endl;
}
return 2;
}),
create_task([]() -> int {
for (int i = 0; i < 100; i++) {
wcout << "thread 3: " << i << endl;
}
return 3;
}),
create_task([]() -> int {
for (int i = 0; i < 100; i++) {
wcout << "thread 4: " << i << endl;
}
return 4;
}),
create_task([]() -> int {
for (int i = 0; i < 100; i++) {
wcout << "thread 5: " << i << endl;;
}
return 5;
})
};
auto joinTask = when_all(begin(tasks), end(tasks)).then([](vector<int> results)
{
for_each(begin(results), end(results), [](int a) {
wcout << a << endl;
});
});
joinTask.wait();
}
. 不隶属于 StackOverflow