ctkEADefaultThreadPool_p.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*=============================================================================
  2. Library: CTK
  3. Copyright (c) German Cancer Research Center,
  4. Division of Medical and Biological Informatics
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #ifndef CTKEADEFAULTTHREADPOOL_P_H
  16. #define CTKEADEFAULTTHREADPOOL_P_H
  17. #include "ctkEAPooledExecutor_p.h"
  18. /**
  19. * A thread pool that allows to execute tasks using pooled threads in order
  20. * to ease the thread creation overhead.
  21. */
  22. class ctkEADefaultThreadPool : public ctkEAPooledExecutor
  23. {
  24. public:
  25. /**
  26. * Create a new pool.
  27. */
  28. ctkEADefaultThreadPool(int poolSize, bool syncThreads);
  29. /**
  30. * Configure a new pool size.
  31. */
  32. void configure(int poolSize);
  33. /**
  34. * Close the pool i.e, stop pooling threads. Note that subsequently, task will
  35. * still be executed but no pooling is taking place anymore.
  36. */
  37. void close();
  38. /**
  39. * Execute the task in a free thread or create a new one.
  40. * @param task The task to execute
  41. */
  42. void executeTask(ctkEARunnable* task);
  43. };
  44. #endif // CTKEADEFAULTTHREADPOOL_P_H