当我运行我的代码时:
#ifndef CPP_PLAZZA_EXAMPLE_H
#define CPP_PLAZZA_EXAMPLE_H
#include <thread>
#include <vector>
#include <list>
#include <memory>
#include <functional>
#include <mutex>
#include <condition_variable>
#include <atomic>
#include <iterator>
#include <tuple>
class ThreadPool
{
public:
ThreadPool(size_t numThreads);
virtual ~ThreadPool();
void executeJob(std::function<void()> job, std::function<void()> notificationJob);
void wait_for_done();
private:
void loop();
std::pair<std::function<void()>, std::function<void()> > getNextJob();
std::vector<std::thread> m_workers;
std::list<std::pair<std::function<void()>, std::function<void()> > > m_jobs;
std::mutex m_lockJobsList;
std::condition_variable m_notifyJob;
std::atomic<bool> m_bTerminate;
class Terminated: public std::runtime_error
{
public:
Terminated(const std::string& what): std::runtime_error(what) {}
};
};
#endif //CPP_PLAZZA_EXAMPLE_H
在抛出'std :: system_error'l
的实例后终止调用what():参数无效
#include <iostream>
#include "example.h"
ThreadPool::ThreadPool(size_t numThreads):
m_workers(numThreads), m_bTerminate(false) {
m_workers.reserve(numThreads);
for (size_t i = 0; i < numThreads; i++) {
this->m_workers.emplace_back(&ThreadPool::loop, this);
}
/*for (std::vector<std::thread>::iterator it = this->m_workers.begin(); it != this->m_workers.end(); it++)
assert(std::next(it, 1) ==);*/
}
ThreadPool::~ThreadPool() {
{
std::unique_lock<std::mutex> lockList(m_lockJobsList);
m_bTerminate = true;
m_notifyJob.notify_all();
}
/* for(std::vector<std::thread>::iterator it = m_workers.begin(); it != m_workers.end(); it++) {
it->join();
}*/
std::this_thread::sleep_for(std::chrono::seconds(5));
}
void ThreadPool::executeJob(std::function<void()> job, std::function<void()> notificationJob) {
std::unique_lock<std::mutex> lockList(m_lockJobsList);
m_jobs.emplace_back(std::pair<std::function<void()>, std::function<void()> >(std::move(job), std::move(notificationJob)));
std::cout << m_jobs.size() << std::endl;
m_notifyJob.notify_one();
}
std::pair<std::function<void()>, std::function<void()> > ThreadPool::getNextJob() {
std::unique_lock<std::mutex> lockList(m_lockJobsList);
while(!m_bTerminate)
{
if(!m_jobs.empty())
{
std::pair<std::function<void()>, std::function<void()>> job = std::ref(m_jobs.front());
m_jobs.pop_front();
return job;
}
m_notifyJob.wait(lockList);
}
throw Terminated("Thread terminated");
}
void func1() {
std::cout << "HELLO I'm func1" << std::endl;
}
void ThreadPool::loop()
{
try
{
for(;;)
{
std::pair<std::function<void()>, std::function<void()> > job = getNextJob();
job.first();
job.second();
}
}
catch(Terminated& e)
{
}
}
void func2() {
std::cout << "BYE I'm func2" << std::endl;
}
void ThreadPool::wait_for_done()
{
std::cout << "nb workers = " << this->m_workers.size() << std::endl;
int i = 0;
for(std::vector<std::thread>::iterator it = m_workers.begin(); it != m_workers.end(); ++it) {
std::cout << "je suis i : " << i << std::endl;
i++;
(*it).join();
}
}
int main()
{
ThreadPool pool(6);
pool.executeJob(func1, func2);
pool.wait_for_done();
}
这是我的.cpp
g++ -Wall -Werror -W -Wextra example.cpp -pthread -std=c++11
我认为我的错误是我在一个帖子上加入了几次,但是如何修复它?
编译行:
for(std::vector<std::thread>::iterator it = m_workers.begin(); it != m_workers.end(); ++it) {
if ((*it).joinable())
(*it).join();
}
我尝试加入之前就像这样加入(等待完成):
def button_duplicate_register(self):
new_sale_order_id = self.copy().id
return {
'type': 'ir.actions.act_window',
'res_model': 'sale.order',
'view_type': 'form',
'view_mode': 'form',
'target': 'current',
'res_id': new_sale_order_id,
'flags': {'form': {'action_buttons': True, 'options': {'mode': 'edit'}}},
}
我有一个无限循环
答案 0 :(得分:2)
您的m_lockJobsList
互斥锁(和m_notifyJob
condvar)在m_workers
线程之前被破坏,这些线程在ThreadPool
析构函数的condvar通知后唤醒时尝试锁定它。