In my code there are three concurrent routines. I try to give a brief overview of my code,
Routine 1 {
do something
*Send int to Routine 2
Send int to Routine 3
Print Something
Print Something*
do something
}
Routine 2 {
do something
*Send int to Routine 1
Send int to Routine 3
Print Something
Print Something*
do something
}
Routine 3 {
do something
*Send int to Routine 1
Send int to Routine 2
Print Something
Print Something*
do something
}
main {
routine1
routine2
routine3
}
I want that, while codes between two do something (codes between two star marks) is executing, flow of control must not go to other goroutines. For example, when routine1 is executing the events between two stars (sending and printing events), routine 2 and 3 must be blocked (means flow of execution does not pass to routine 2 or 3 from routine 1). After completing last print event, flow of execution may pass to routine 2 or 3. Can anybody help me by specifying, how can I achieve this ? Is it possible to implement above specification by WaitGroup ? Can anybody show me by giving a simple example how to implement above specified example by using WaitGroup. Thanks.
NB: I give two sending and two printing options, in fact there is lots of sending and printing.
If I have gotten it correctly, what you want is to prevent simultaneous execution of some part of each function and other functions. The following code does this:
fmt.Printlnlines won’t happen as other routines are running. Here’s what happens: when execution gets to the print section, it waits until other routines end, if they are running, and while this print line is executing other routines don’t start and wait. I hope that is what you are looking for. Correct me if I’m wrong about this.UPDATE: Let me explain these three mutex here: a mutex is, as documentation says: “a mutual exclusion lock.” That means when you call
Lockon a mutex your code just waits there if somebody else have locked the same mutex. Right after you callUnlockthat blocked code will be resumed.Here I put each function in its own mutex by locking a mutex at the beginning of the function and unlocking it the end. By this simple mechanism you can avoid running any part of code you want at the same time as those functions. For instance, everywhere you want to have a code that should not be running when
Routine1is running, simply lockmutex1at the beginning of that code and unlock at at the end. That is what I did in appropriate lines inRoutine2andRoutine3. Hope that clarifies things.