/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
-#include <functional>
-#include <mutex>
+#include <mutex> /* std::mutex and std::lock_guard */
+#include "simgrid/s4u.hpp" /* All of S4U */
-#include <xbt/sysdep.h>
-
-#include "simgrid/s4u.hpp"
-
-#define NB_ACTOR 2
+#define NB_ACTOR 6
XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_test, "a sample log category");
+/* This worker uses a classical mutex */
static void worker(simgrid::s4u::MutexPtr mutex, int& result)
{
- // Do the calculation
- simgrid::s4u::this_actor::execute(1000);
-
// lock the mutex before enter in the critical section
- std::lock_guard<simgrid::s4u::Mutex> lock(*mutex);
- XBT_INFO("Hello s4u, I'm ready to compute");
+ mutex->lock();
+ XBT_INFO("Hello s4u, I'm ready to compute after a regular lock");
// And finaly add it to the results
result += 1;
XBT_INFO("I'm done, good bye");
+
+ // You have to unlock the mutex if you locked it manually.
+ // Beware of exceptions preventing your unlock() from being executed!
+ mutex->unlock();
}
static void workerLockGuard(simgrid::s4u::MutexPtr mutex, int& result)
{
- simgrid::s4u::this_actor::execute(1000);
-
// Simply use the std::lock_guard like this
+ // It's like a lock() that would do the unlock() automatically when getting out of scope
std::lock_guard<simgrid::s4u::Mutex> lock(*mutex);
// then you are in a safe zone
- XBT_INFO("Hello s4u, I'm ready to compute");
+ XBT_INFO("Hello s4u, I'm ready to compute after a lock_guard");
// update the results
result += 1;
XBT_INFO("I'm done, good bye");
+
+ // Nothing specific here: the unlock will be automatic
}
static void master()
#! ./tesh
$ $SG_TEST_EXENV ${bindir:=.}/s4u_mutex
->[Tremblay:worker:(0) 0.000080] [s4u_test/INFO] Hello s4u, I'm ready to compute
->[Tremblay:worker:(0) 0.000080] [s4u_test/INFO] I'm done, good bye
->[Tremblay:worker:(0) 0.000080] [s4u_test/INFO] Hello s4u, I'm ready to compute
->[Tremblay:worker:(0) 0.000080] [s4u_test/INFO] I'm done, good bye
->[Jupiter:worker:(0) 0.000160] [s4u_test/INFO] Hello s4u, I'm ready to compute
->[Jupiter:worker:(0) 0.000160] [s4u_test/INFO] I'm done, good bye
->[Jupiter:worker:(0) 0.000160] [s4u_test/INFO] Hello s4u, I'm ready to compute
->[Jupiter:worker:(0) 0.000160] [s4u_test/INFO] I'm done, good bye
->[Tremblay:main:(0) 10.000000] [s4u_test/INFO] Results is -> 4
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a lock_guard
+> [Jupiter:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] Hello s4u, I'm ready to compute after a regular lock
+> [Tremblay:worker:(0) 0.000000] [s4u_test/INFO] I'm done, good bye
+> [Tremblay:main:(0) 10.000000] [s4u_test/INFO] Results is -> 12