mirror of
				https://github.com/usatiuk/backup.git
				synced 2025-10-26 09:27:48 +01:00 
			
		
		
		
	Small ThreadPool improvements
This commit is contained in:
		| @@ -8,16 +8,17 @@ ThreadPool::ThreadPool(std::function<void(std::string)> onError, std::size_t wor | ||||
| } | ||||
|  | ||||
| ThreadPool::~ThreadPool() { | ||||
|     { | ||||
|         std::lock_guard lock(queueLock); | ||||
|         stop = true; | ||||
|         somethingNew.notify_all(); | ||||
|     } | ||||
|     for (auto &t: threads) { t.join(); } | ||||
| } | ||||
|  | ||||
| void ThreadPool::push(std::function<void()> &&func) { | ||||
|     { | ||||
|     std::lock_guard lock(queueLock); | ||||
|     queue.push(std::move(func)); | ||||
|     } | ||||
|     somethingNew.notify_one(); | ||||
| } | ||||
|  | ||||
| @@ -43,17 +44,14 @@ void ThreadPool::loop() { | ||||
|         queue.pop(); | ||||
|  | ||||
|         qLock.unlock(); | ||||
|  | ||||
|         try { | ||||
|             task(); | ||||
|         } catch (std::exception &e) { onError(std::string(e.what())); } | ||||
|         qLock.lock(); | ||||
|  | ||||
|         { | ||||
|             std::lock_guard qLock(queueLock); | ||||
|         running--; | ||||
|         if (queue.empty() && running == 0) { finished.notify_all(); } | ||||
|     } | ||||
|     } | ||||
| } | ||||
|  | ||||
| bool ThreadPool::empty() { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user