| OpenShot Audio Library | OpenShotAudio 0.4.0
    | 
#include <juce_ThreadPool.h>
| Classes | |
| class | JobSelector | 
| Public Types | |
| using | Options = ThreadPoolOptions | 
| Public Member Functions | |
| ThreadPool (const Options &options) | |
| ThreadPool () | |
| ThreadPool (int numberOfThreads, size_t threadStackSizeBytes=Thread::osDefaultStackSize, Thread::Priority desiredThreadPriority=Thread::Priority::normal) | |
| ~ThreadPool () | |
| void | addJob (ThreadPoolJob *job, bool deleteJobWhenFinished) | 
| void | addJob (std::function< ThreadPoolJob::JobStatus()> job) | 
| void | addJob (std::function< void()> job) | 
| bool | removeJob (ThreadPoolJob *job, bool interruptIfRunning, int timeOutMilliseconds) | 
| bool | removeAllJobs (bool interruptRunningJobs, int timeOutMilliseconds, JobSelector *selectedJobsToRemove=nullptr) | 
| int | getNumJobs () const noexcept | 
| int | getNumThreads () const noexcept | 
| ThreadPoolJob * | getJob (int index) const noexcept | 
| bool | contains (const ThreadPoolJob *job) const noexcept | 
| bool | isJobRunning (const ThreadPoolJob *job) const noexcept | 
| bool | waitForJobToFinish (const ThreadPoolJob *job, int timeOutMilliseconds) const | 
| void | moveJobToFront (const ThreadPoolJob *jobToMove) noexcept | 
| StringArray | getNamesOfAllJobs (bool onlyReturnActiveJobs) const | 
A set of threads that will run a list of jobs.
When a ThreadPoolJob object is added to the ThreadPool's list, its runJob() method will be called by the next pooled thread that becomes free.
Definition at line 200 of file juce_ThreadPool.h.
Definition at line 203 of file juce_ThreadPool.h.
| 
 | explicit | 
Creates a thread pool based on the provided options. Once you've created a pool, you can give it some jobs by calling addJob().
Definition at line 97 of file juce_ThreadPool.cpp.
| 
 | inline | 
Creates a thread pool based using the default arguments provided by ThreadPoolOptions.
Once you've created a pool, you can give it some jobs by calling addJob().
Definition at line 220 of file juce_ThreadPool.h.
| juce::ThreadPool::ThreadPool | ( | int | numberOfThreads, | 
| size_t | threadStackSizeBytes = Thread::osDefaultStackSize, | ||
| Thread::Priority | desiredThreadPriority = Thread::Priority::normal ) | 
Creates a thread pool. Once you've created a pool, you can give it some jobs by calling addJob().
| numberOfThreads | the number of threads to run. These will be started immediately, and will run until the pool is deleted. | 
| threadStackSizeBytes | the size of the stack of each thread. If this value is zero then the default stack size of the OS will be used. | 
| desiredThreadPriority | the desired priority of each thread in the pool. | 
Definition at line 109 of file juce_ThreadPool.cpp.
| juce::ThreadPool::~ThreadPool | ( | ) | 
Destructor.
This will attempt to remove all the jobs before deleting, but if you want to specify a timeout, you should call removeAllJobs() explicitly before deleting the pool.
Definition at line 118 of file juce_ThreadPool.cpp.
| void juce::ThreadPool::addJob | ( | std::function< ThreadPoolJob::JobStatus()> | job | ) | 
Adds a lambda function to be called as a job. This will create an internal ThreadPoolJob object to encapsulate and call the lambda.
Definition at line 155 of file juce_ThreadPool.cpp.
| void juce::ThreadPool::addJob | ( | std::function< void()> | job | ) | 
Adds a lambda function to be called as a job. This will create an internal ThreadPoolJob object to encapsulate and call the lambda.
Definition at line 168 of file juce_ThreadPool.cpp.
| void juce::ThreadPool::addJob | ( | ThreadPoolJob * | job, | 
| bool | deleteJobWhenFinished ) | 
Adds a job to the queue.
Once a job has been added, then the next time a thread is free, it will run the job's ThreadPoolJob::runJob() method. Depending on the return value of the runJob() method, the pool will either remove the job from the pool or add it to the back of the queue to be run again.
If deleteJobWhenFinished is true, then the job object will be owned and deleted by the pool when not needed - if you do this, make sure that your object's destructor is thread-safe.
If deleteJobWhenFinished is false, the pointer will be used but not deleted, and the caller is responsible for making sure the object is not deleted before it has been removed from the pool.
Definition at line 133 of file juce_ThreadPool.cpp.
| 
 | noexcept | 
Returns true if the given job is currently queued or running.
Definition at line 198 of file juce_ThreadPool.cpp.
Referenced by waitForJobToFinish(), and juce::ThreadPoolJob::~ThreadPoolJob().
| 
 | noexcept | 
Returns one of the jobs in the queue.
Note that this can be a very volatile list as jobs might be continuously getting shifted around in the list, and this method may return nullptr if the index is currently out-of-range.
Definition at line 192 of file juce_ThreadPool.cpp.
| StringArray juce::ThreadPool::getNamesOfAllJobs | ( | bool | onlyReturnActiveJobs | ) | const | 
Returns a list of the names of all the jobs currently running or queued. If onlyReturnActiveJobs is true, only the ones currently running are returned.
Definition at line 325 of file juce_ThreadPool.cpp.
| 
 | noexcept | 
Returns the number of jobs currently running or queued.
Definition at line 181 of file juce_ThreadPool.cpp.
| 
 | noexcept | 
Returns the number of threads assigned to this thread pool.
Definition at line 187 of file juce_ThreadPool.cpp.
| 
 | noexcept | 
Returns true if the given job is currently being run by a thread.
Definition at line 204 of file juce_ThreadPool.cpp.
Referenced by removeAllJobs().
| 
 | noexcept | 
If the given job is in the queue, this will move it to the front so that it is the next one to be executed.
Definition at line 210 of file juce_ThreadPool.cpp.
| bool juce::ThreadPool::removeAllJobs | ( | bool | interruptRunningJobs, | 
| int | timeOutMilliseconds, | ||
| ThreadPool::JobSelector * | selectedJobsToRemove = nullptr ) | 
Tries to remove all jobs from the pool.
| interruptRunningJobs | if true, then all running jobs will have their ThreadPoolJob::signalJobShouldExit() methods called to try to interrupt them | 
| timeOutMilliseconds | the length of time this method should wait for all the jobs to finish before giving up and returning false | 
| selectedJobsToRemove | if this is not a nullptr, the JobSelector object is asked to decide which jobs should be removed. If it is a nullptr, all jobs are removed | 
Definition at line 267 of file juce_ThreadPool.cpp.
Referenced by ~ThreadPool().
| bool juce::ThreadPool::removeJob | ( | ThreadPoolJob * | job, | 
| bool | interruptIfRunning, | ||
| int | timeOutMilliseconds ) | 
Tries to remove a job from the pool.
If the job isn't yet running, this will simply remove it. If it is running, it will wait for it to finish.
If the timeout period expires before the job finishes running, then the job will be left in the pool and this will return false. It returns true if the job is successfully stopped and removed.
| job | the job to remove | 
| interruptIfRunning | if true, then if the job is currently busy, its ThreadPoolJob::signalJobShouldExit() method will be called to try to interrupt it. If false, then if the job will be allowed to run until it stops normally (or the timeout expires) | 
| timeOutMilliseconds | the length of time this method should wait for the job to finish before giving up and returning false | 
Definition at line 238 of file juce_ThreadPool.cpp.
| bool juce::ThreadPool::waitForJobToFinish | ( | const ThreadPoolJob * | job, | 
| int | timeOutMilliseconds ) const | 
Waits until a job has finished running and has been removed from the pool.
This will wait until the job is no longer in the pool - i.e. until its runJob() method returns ThreadPoolJob::jobHasFinished.
If the timeout period expires before the job finishes, this will return false; it returns true if the job has finished successfully.
Definition at line 220 of file juce_ThreadPool.cpp.
Referenced by removeJob().