//---------------------------------------------------- // tasb.cc //---------------------------------------------------- #include #include #include //---------------------------------------------------- using namespace std::literals; //---------------------------------------------------- const size_t N = 32; std::atomic start = false, stop = false; //---------------------------------------------------- class cerrojo { public: void adquirir() { while (cerrado || __sync_lock_test_and_set(&cerrado, true)); } void liberar() { cerrado = false; } private: volatile bool cerrado = false; } c; //---------------------------------------------------- void seccion_critica() { std::cout << "[" << std::this_thread::get_id() << "]: "; for (size_t i = 0; i < 10; ++i) std::cout << i; std::cout << std::endl; } //---------------------------------------------------- void hebra() { while (!start) std::this_thread::yield(); while (!stop) { c.adquirir(); if (!stop) seccion_critica(); c.liberar(); } } //---------------------------------------------------- int main() { std::thread threads[N]; for (auto &t : threads) t = std::thread(hebra); start = true; std::this_thread::sleep_for(100ms); stop = true; for (auto &t : threads) t.join(); } //----------------------------------------------------