Explanation of this topic starts with an analogy taking an example from real life to better understand the concept.
It was afternoon when John was going to office and he told his wife Shahana that he will come by 5:00 in the evening. He told her to keep the tea ready by then.
Shahana cared for her husband. So the first thing that she did was to check if all ingredients required for making tea are there. Everything was fine except sugar which was in less quantity but it was enough to make tea for her husband.
She felt satisfied and went to have sleep for few hours before her husband comes. While she was sleeping, their maid came and performed her regular household tasks.
After completing her tasks, she felt tired and so she thought to have a cup of tea. Usually, she asks shahana before using anything from kitchen but, since shahana was sleeping she proceeded with making a cup of tea for herself.
She saw that everything required for making tea was available in the kitchen. It took few minutes for tea to be ready. She drank and left.
Till this point, story looked bit plain but problem starts now.
Shahana woke up and since she was sure that there is enough quantity of each ingredient for making tea, she started making it.
In between the process of making, she realised that the sugar is not there.OH MY GOD !!
WHAT SHALL SHE DO NOW?
If we see the above example, shahana and maid are 2 processes which are trying to access a common resource which is sugar.
Same situation can occur in concurrent programming environment when there is single resource (object/ variable) being accessed and modified by more than one process.
Operating system can put a running process on hold and allow another process to use CPU for some time.
Now it can happen that the new process is also modifying the same resource which was being accessed by the former process and hence the chances of occurrence of race condition erupt !!
Please hit the ♥ button if you liked the article so that other Medium users might find it and dig it too.