I've seen most examples using std::mutex where the mutex is global. I was wondering is there any specific reason why this is done? I've had programs of my own where I don't do this, and simply pass the mutex in as a std::thread std::ref. Isn't it bad practice to have globals, what is the rational behind global std::mutexes in C++ if there is no language restricting reason to do this?
Is there any reason C++ 11+ std::mutex should be declared as a global variable instead of passed into a std::thread as a function parameter?
8.2k Views Asked by Krupip At
2
There are 2 best solutions below
0
Mark B
On
Most likely this was done to make the example easier to follow, allowing the use of the mutex itself to be the focus of the example rather than the exact specifics.
Typically a mutex protects a resource and in many cases it makes sense for the mutex to live alongside the resource. For example if you have a class with a member container that needs to be protected by a mutex, make the mutex also a member of the class. Then as the class instance is acted on by multiple threads the member-mutex can be used to protect the needed accesses to the internal container.
Related Questions in C++
- How to immediately apply DISPLAYCONFIG_SCALING display scaling mode with SetDisplayConfig and DISPLAYCONFIG_PATH_TARGET_INFO
- Why can't I use templates members in its specialization?
- How to fix "Access violation executing location" when using GLFW and GLAD
- Dynamic array of structures in C++/ cannot fill a dynamic array of doubles in structure from dynamic array of structures
- How do I apply the interface concept with the base-class in design?
- File refuses to compile std::erase() even if using -std=g++23
- How can I do a successful map when the number of elements to be mapped is not consistent in Thrust C++
- Can std::bit_cast be applied to an empty object?
- Unexpected inter-thread happens-before relationships from relaxed memory ordering
- How i can move element of dynamic vector in argument of function push_back for dynamic vector
- Brick Breaker Ball Bounce
- Thread-safe lock-free min where both operands can change c++
- Watchdog Timer Reset on ESP32 using Webservers
- How to solve compiler error: no matching function for call to 'dmhFS::dmhFS()' in my case?
- Conda CMAKE CXX Compiler error while compiling Pytorch
Related Questions in MULTITHREADING
- How can I outsource worker processes within a for loop?
- OpenMP & oneTbb difference
- Receiving Notifications for Individual Task Completion OmniThreadLibrary Parallel.ForEach
- C++ error: no matching member function for call to 'enqueue' futures.emplace_back(TP.enqueue(sum_plus_one, x, &M));
- How can I create a thread in Haskell that will restart if it gets killed due to any reason?
- Qt: running callback in the main thread from the worker thread
- Using `static` on a AVX2 counter function increases performance ~10x in MT environment without any change in Compiler optimizations
- Heap sort with multithreading
- windows multithreading CreateMutex
- The problem of "fine-grained locks and two-phase locking algorithm"
- OpenMP multi-threading not working if OpenMPI set to use one or two MPI processor
- WPF Windows Initializing is locking the separated thread in .Net 8
- TCP Client Losing Connection When Writing Data
- vc++ thread constructor throwing compiler error c2672
- ASP.NET Core 6 Web API : best way to pause before resending email
Related Questions in MUTEX
- Can defer recover prevent mutex Unlock?
- In Rust, how to coerce a mutex lock into a reference with identical lifetime?
- Binary Semaphore vs Mutux interview question
- Shared variable read from low priority thread in preemptive scheduling
- Ruby Threads Concurrency Issue using Mutex
- How does mutex work in multicore systems?
- why can't the following mutex be shared by multiple threads?
- Borrowing issues using variables wrapped in Arc<Mutex<>> in Rust
- Eliminating concurrency bugs with mutexes
- Returning variable by reference requires holding mutex
- Do I need mutexes for read operation only?
- Mutex doesn't stop more than one coroutine to modify or read the data
- How do I disable the eventual fairness of the Rust parking_lot crate's Mutex?
- How to prevent race condition when multiple threads are writing in the same file descriptor in C?
- How to ensure consistency in process synchronization
Related Questions in STDTHREAD
- Problem with g++ on Mac using std::thread and exceptions
- getting core dump in this simple threading program in C++
- C++ lambda used in std::thread crash
- What is wrong with this C++ multi-threaded program?
- How can I run a detached thread that is waiting for a conditional variable in a loop?
- Write-read conflicts in Linux C++ IO concurrency
- Check if a function argument value is thread-local
- Constness ignored when forwarding std::reference_wrapper to lambda argument
- Does condition variable notify_one keep trying until it reaches thread awaiting with a positive predicate?
- How to design a base class that needs to join a thread in its destructor, which operates on the same class instance?
- When using std::thread class, why exactly can I pass lambda expression that capture variables by reference?
- Compiler error: "invoke: No matching overloaded function found" when creating a new thread
- Why std::thread accepts generic lambdas but not templated functions (without explicit instantiation)?
- Why std::thread() passes arguments by value (and why the reason given by Dr. Stroustrup is incorrect)?
- Check if an std::thread finished execution without std::thread::join()
Related Questions in STDMUTEX
- Why std::mutex of c++11 has no memory order?
- reduction operation using OpenCV ForEach, but thread-safe and faster?
- How to synchronize this special case of threads with C++ std::thread
- std::lock_guard does not lock the mutex as expected
- Is `std::shared_mutex` virtually a superset of `std::mutex`?
- std::shared_lock release() method - how to use?
- I cannot use mutex along with vector
- Is there any way I can lock a list of mutex?
- Questions regarding lock-free vs mutex solution for Leetcode 1117: Building H2O
- Is there a need to provide a std::mutex for std::async?
- Iterating over vector in one thread while other may potentially change reference
- Horrible scalability of std::mutex with zero contention
- Why can mutex be used in different threads?
- Destructor, when object's dynamic variable is locked by mutex will not free it?
- destroy std::mutex vs pthread_mutex_t
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
It's bad practice to have globals except when it isn't. For example,
std::cinis global.Mutexes are in a sense global, regardless of how you make them available. They're shared between disparate pieces of code. So you can make them globals, or you can pass them down the call chain, through functions that don't use them, until you eventually reach someone who does. That's known as "tramp data" and it's also "bad practice". Choose your poison.