Posts

Showing posts from December, 2024

C++ Condition Variable

Image
Sharing the code which demonstrates synchronization between two threads. Two threads execute interchangeably, all thanks to the condition variable. I have also shared the code execution output   Check out the Video: #include <iostream> #include <thread> #include <mutex> #include <condition_variable> using namespace std; mutex m; condition_variable cnd; int previousThreadId; void print(int threadID) { for (size_t i = 0; i < 20; i++) { unique_lock<std::mutex> ul(m); //->Threads Waiting Zone cnd.wait(ul, [&]()->bool {    if (threadID != previousThreadId) return true; else return false; }); previousThreadId = threadID; cout << "\nThread # " << threadID << " Executing..."; cout << "\nPrinting  : " << i<< "\n"; ul.unlock(); cnd.notify_one(); } } int main() { thread t[2]; for (size_t i = 0; i < 2; i++) { t[i] = th...

Unveiling Function Hiding in C++: Why Polymorphism Isn’t Parameter-Dependent?

Image
Function Hiding in C++: Understanding the Hidden Layers When working with C++, you’ve likely encountered situations where functions behave unexpectedly due to name collisions, inheritance, or ambiguous scope resolution. This phenomenon, function hiding , is a common challenge for developers. In this post, we’ll break down the mechanics of function hiding, explore its implications in object-oriented programming, and clarify why C++ does not support polymorphism for functions that differ only by their parameters . Let’s dive into function hiding and uncover the key aspects you need to know. What is Function Hiding in C++? Function hiding occurs when a derived class defines a member function with the same name as a function in its base class. In this case, the function in the derived class hides the function in the base class, regardless of their parameter lists or signatures. This behavior can confuse developers who expect polymorphism to handle calls to functions with the sam...