I am just starting play with multithreading programming. I would like to my program show alternately character '-' and '+' but it doesn't. My task is to use synchronized keyword. As far I have:
class FunnyStringGenerator{
private char c;
public FunnyStringGenerator(){
c = '-';
}
public synchronized char next(){
if(c == '-'){
c = '+';
}
else{
c = '-';
}
return c;
}
}
class ThreadToGenerateStr implements Runnable{
FunnyStringGenerator gen;
public ThreadToGenerateStr(FunnyStringGenerator fsg){
gen = fsg;
}
@Override
public void run() {
for(int i = 0; i < 10; i++){
System.out.print(gen.next());
}
}
}
public class Main{
public static void main(String[] args) throws IOException {
FunnyStringGenerator FSG = new FunnyStringGenerator();
ExecutorService exec = Executors.newCachedThreadPool();
for(int i = 0; i < 20; i++){
exec.execute(new ThreadToGenerateStr(FSG));
}
}
}
EDIT: I also testing Thread.sleep in run method instead for loop.
Your synchronized block in FunnyStringGenerator.next() is working fine. It will return '+' and '-' alternately.
However you have a race condition in ThreadToGenerateStr.run():
System.out.print(gen.next());
This is equivalent to:
char c = gen.next(); // Synchronized
System.out.print(c); // Not synchronized
The problem occurs when:
The result is that the '+' and '-' are written in the opposite order.
There are various possible workarounds, e.g.:
synchronized block (as in dogbane's answer)If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With