Threads control using wait/notify. Producer/Consumer
-
Execute and check how the program works, Execute jVisualVM and inspect the CPU use of the corresponding process.
What is the reason of this CPU consumption?
That both threads are always trying to either consume or produce numbers even when it's possible to do it
What is the class responsable of that consumption?
The producer class, always trying to put up more numbers
-
Write some code in order to solve the CPU's use problems , having in mind that for now the production is slow and the consumption is fast, check that the CPU consumption has decreased.
-
Make a producer that produces as fast as it can, and the consumer consumes slow, keeping in mind that the producer knows a Stock limit (how many elements have to have at most in the queue) your code has to respect that limit.Check the Collection API used as queue in order to validate that the limit not be exceeded.Verify that when you set a small limit in the stock, there is not a high CPU consumption or errors. So that, altogether we are exploring the total of servers
Keeping in mind the race condition concept and synchronization. Make a new version more efficient of the previous exercise.(The Black List search). In the current version, each thread is in charge of check the host in each subset of servers that is assigned to it. So that, altogether it explores the total of servers.
Considering this:
1.Make that the distributed search stops (Stop looking at the remaining blacklists) return the answer when the threads in its set have detected number of occurrences required to determine if a host is truswhorthy or not(BLACK_LIST_ALARM_COUNT)
2.The above, ensuring that there are no race conditions
Synchronization and deadlocks
- Check the "Highlander-simulator" program, you can find it in edu.eci.arsw.highlandersim package. This is a game in which:
-
There are N players
-
Each player knows the other N-1 remaining players
-
Each player, permanently, attacks other inmortal. The firstone who attacks substract m life points to the opponent, and increase in the same quantity his life points.
-
The game could never have an unique winner. The most likely thing is that in the end there are only two, fighting forever substracting and adding lifepoints
- Check the code and identify how the indicated funcionality was implemented. Given the purpose of the game, an invariant should be that the sum of the life points of all the players always be the same.(Of course, in a moment of time when an operation of increase / reduction of time is not in process). For that case, for N players, what should be that value?
For N player the total health should be N*100
- Run the application and verify how the "pause and check" option works, is the invariant satisfied?
No the total health changes with the time
-
A first hypothesis for presenting the race condition for that function (pause and check) is that the program check the list whose values are going to print, at the same time other threads modify the list's values. In order to solve that write the necessary code to effectively, before print the current results, pause the other threads. Also, implement the resume option
-
Verify again the functionality clicking many times. Is the invariant satisfied?
No, the fight funciton should be synchronized for it
- Identify possible critical regions in regards to the fight of the immortals.Implement a lock strategy to avoid the race conditions. Remember that if you need use two or more 'locks' simultaneously you can use nested sychronized blocks.
the fight method where the reduction or amplification of the health goes
-
After implementing your strategy. Run the program and pay attention if it stops. In that case, use the jps and jstacks programs to identify why the program stops its execution
-
Think a strategy in order to solve the problem identified(you can check again the 206 and 207 pages of the "Java Concurrency in practice")
-
When you have solved the problem, check that the program continues working with consistency when executing 100,1000 or 10000 inmortals. If with large amount of immortals you breach the invariant again. You have to analyze it again (step 4)
-
An annoying element of the simulation, that is certain point thereof , there are few alive immortals fighting failed with dead immortals.Is needed to delete the dead inmortals in the simulation when they are dying, for that:
Analizing how the simulation works. this could create a race condition? Implement the functionality , run the simulation and observe what problem is presented when there are many inmortals. Write some conclutions in the Answers.txt file
Yes it could create it, because when trying to eliminate an inmortal, anotherone could be trying to access it's information
Solve the problem identified above without use Sinchronization, cause the sequentiallity of the process would make extremely slow the simulation
- Finally, implement the stop option