(emphasis mine)

The lifetime of the thread is often dependent on the work in which the thread is doing. For example, if a thread is created to perform a computationally expensive calculation, then the thread can exit once the result has been calculated. If the work is short-lived, then the overhead of creating and destroying threads can affect performance.

A thread pool is a pattern, where a number of threads services a number of task/work. The lifetime of the thread is not directly associated with the lifetime of the task.

As an example, an application may schedule the computationally expensive calculation to run within a thread pool. The work will be queued within the thread pool, and one of the thread pool's threads will be selected to perform the work. Once the calculation has completed, the thread goes back to waiting for more work to be scheduled with the thread pool.

(@tanner-sansbury)