基于C++ Coroutines提案 ‘Stackless Resumable Functions’编写的协程库
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

test_async_resumable.cpp 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #include <chrono>
  2. #include <iostream>
  3. #include <string>
  4. #include <conio.h>
  5. #include "librf.h"
  6. static std::mutex lock_console;
  7. template <typename T>
  8. void dump(size_t idx, std::string name, T start, T end, intptr_t count)
  9. {
  10. lock_console.lock();
  11. auto ns = std::chrono::duration_cast<std::chrono::nanoseconds>(end - start).count();
  12. std::cout << idx << ":" << name << " ";
  13. std::cout << count << " " << ns << " ns ";
  14. std::cout << (ns / count) << " ns/op" << " ";
  15. std::cout << (count * 100ll * 1000ll / ns) << "w/cps" << std::endl;
  16. lock_console.unlock();
  17. }
  18. static const intptr_t N = 3000000;
  19. //static const int N = 10;
  20. auto yield_switch(intptr_t coro) -> resumef::generator_t<intptr_t>
  21. {
  22. for (intptr_t i = 0; i < N / coro; ++i)
  23. co_yield i;
  24. return N / coro;
  25. }
  26. void resumable_switch(intptr_t coro, size_t idx)
  27. {
  28. resumef::local_scheduler ls;
  29. auto start = std::chrono::steady_clock::now();
  30. for (intptr_t i = 0; i < coro; ++i)
  31. {
  32. //go yield_switch(coro);
  33. go [=] ()->resumef::generator_t<intptr_t>
  34. {
  35. for (intptr_t i = 0; i < N / coro; ++i)
  36. co_yield i;
  37. co_return N / coro;
  38. };
  39. }
  40. auto middle = std::chrono::steady_clock::now();
  41. dump(idx, "BenchmarkCreate_" + std::to_string(coro), start, middle, coro);
  42. resumef::this_scheduler()->run_until_notask();
  43. auto end = std::chrono::steady_clock::now();
  44. dump(idx, "BenchmarkSwitch_" + std::to_string(coro), middle, end, N);
  45. }
  46. void resumable_main_resumable()
  47. {
  48. resumable_switch(1, 0);
  49. //resumable_switch(10, 0);
  50. //resumable_switch(100, 0);
  51. resumable_switch(1000, 0);
  52. resumable_switch(30000, 0);
  53. /*
  54. std::thread works[32];
  55. for (size_t w = 1; w <= _countof(works); ++w)
  56. {
  57. for (size_t idx = 0; idx < w; ++idx)
  58. works[idx] = std::thread(&resumable_switch, 1000, idx);
  59. for (size_t idx = 0; idx < w; ++idx)
  60. works[idx].join();
  61. std::cout << std::endl << std::endl;
  62. }
  63. */
  64. }