Today I wrote some tests with the goal to verify thread safety on a part of production code. Using TDD I wrote a test that started two new threads that both updated the same object, and while they were running I verified the object's data. By putting this in a loop I was able to get a unit test that failed on each run.
By adding locks at the correct places I got the test to pass. But looking at the time it took to run the test I noticed that it was quite slow. I knew that the updates to the object's data were fast and started wondering if it was the start and join of the threads that were slowing it down.
So, instead of using new Thread(task) I switched to using Task.Run(task) and task.Wait() instead of thread.Join(). The main difference here being task adding a job to a pool of worker threads while new Thread creates a completely new thread that is stopped and disposed after it has run to completion.
By doing this small change the test time decreased by 25% (from 800 ms to 600 ms). So, lesson learned, do not start new threads if there is a threadpool available that you can use.
By adding locks at the correct places I got the test to pass. But looking at the time it took to run the test I noticed that it was quite slow. I knew that the updates to the object's data were fast and started wondering if it was the start and join of the threads that were slowing it down.
So, instead of using new Thread(task) I switched to using Task.Run(task) and task.Wait() instead of thread.Join(). The main difference here being task adding a job to a pool of worker threads while new Thread creates a completely new thread that is stopped and disposed after it has run to completion.
By doing this small change the test time decreased by 25% (from 800 ms to 600 ms). So, lesson learned, do not start new threads if there is a threadpool available that you can use.
Kommentarer
Skicka en kommentar