//--------------------------------------------------------- // spinlock-eb.cc //--------------------------------------------------------- #include #include #include #include //--------------------------------------------------------- using namespace std::literals; //--------------------------------------------------------- const size_t N = 2; //--------------------------------------------------------- class barrera_t { public: barrera_t(size_t l) : atrapados(l), limite(l) {} void esperar() { size_t ahora = ciclo; if (--atrapados != 0) { auto tiempo = 2us; while (ahora == ciclo) std::this_thread::sleep_for(tiempo *= 2); } else { ++ciclo; atrapados = limite; } } private: std::atomic atrapados, ciclo = 0; size_t limite; } barrera(N); //--------------------------------------------------------- void hebra(size_t yo) { std::string antes = std::to_string(yo) + ": antes\n", despues = std::to_string(yo) + ": después\n"; while (true) { std::cout << antes; barrera.esperar(); std::cout << despues; } } //--------------------------------------------------------- int main() { for (size_t i = 0; i < N; ++i) std::thread(hebra, i).detach(); std::this_thread::sleep_for(10ms); } //---------------------------------------------------------