pandemonium_engine_docs/04_modules/01_thread_pool.md

112 lines
2.5 KiB
Markdown
Raw Permalink Normal View History

2023-01-12 22:38:57 +01:00
# Thread pool module
2024-05-04 00:04:16 +02:00
Todo: was merged into core.
2024-03-16 20:56:52 +01:00
A c++ Pandemonium engine module, that will help you with threading.
2023-01-12 22:38:57 +01:00
It can also work if threads are not available (like on the javascript backend), in this case it runs jobs on the
main thread. Jobs themselves can also distribute their work onto multiple frames, and you can set how much time
is allocated per frame.
You can access it's setting from the `Project->Project Settings...` menu, in the `ThreadPool` category.
# ThreadPoolJob
Contains a job that can run on different threads.
A job is only considered finished, if you set the 'complete' property to 'true'. If multiple threads are available,
the system will not check for this though, because there is no need.
If you want to support environments that doesn't have threading, you can use:
```
bool should_do(const bool just_check = false);
bool should_return();
```
For example:
```
func _execute():
# On the first run this will return true, on subsequent runs it will return false
if should_do():
thing1()
# if you ran out the allocated timeframe in a frame, this will return true
if should_return():
return
if should_do():
thing2()
if should_return():
return
thing3()
complete = true
```
`should_do`'s optional parameter will let you just query the system, whether you finished a step, without
incrementing internal couters. This is useful for example to distribute algorithms onto multiple frames.
For example:
```
func _execute():
if should_do(true):
while current <= elements.size():
#do heavy calculations
current += 1
if should_return():
return
#The heavy calculation finished, increment counters
should_do()
if should_return():
return
if should_do():
thing2()
if should_return():
return
thing3()
complete = true
```
This class will need little tweaks, hopefully I can get to is soon.
# ThreadPoolExecuteJob
This will let you run a method uin an another thread, without creating your own jobs.
Use it through the ThreadPool Singleton. Like:
```
ThreadPool.create_execute_job(self, "method", arg1, arg2, ...)
#or
ThreadPool.create_execute_job_simple(self, "method")
```
This class will need little tweaks, hopefully I can get to is soon.
# ThreadPool singleton
The ThreadPool singleton handles jobs.
If you have a job, submit it using `add_job`:
```
MyJob job = MyJob.new()
ThreadPool.add_job(job)
```