//---------------------------------------------------- // pthread-m.cc //---------------------------------------------------- #include #include #include //---------------------------------------------------- using namespace std::literals; //---------------------------------------------------- const size_t N = 8; //---------------------------------------------------- pthread_mutex_t mutex; //---------------------------------------------------- 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 (true) { pthread_mutex_lock(&mutex); seccion_critica(); pthread_mutex_unlock(&mutex); } } //---------------------------------------------------- int main() { pthread_mutex_init(&mutex, NULL); std::jthread threads[N]; for (auto &i : threads) i = std::jthread(hebra); } //----------------------------------------------------