我在类
上有以下方法void Listener::Start()
{
Logger logger;
std::string logMessage("Starting '" + to_utf8string(GetName()) + "' Listener");
http_listener httpListener(GetUri());
std::string listenerName(to_utf8string(name));
logger.log(logMessage);
// listener recieves a GET request.
httpListener.support(methods::GET, [listenerName](http_request request)
{
Logger logger;
std::string logMessage("GET request recieved from " + listenerName);
logger.log(logMessage);
// dummy line just till routing is dealt with
request.reply(status_codes::OK, logMessage);
});
// open listener and route request
httpListener
.open()
.then([&httpListener,listenerName](){
Logger logger;
std::string logMessage(listenerName + "started");
logger.log(logMessage);
}).wait();
// JUST WAIT - we do not want the application to stop
while (true);
}
现在我不知道有多少个线程 - 它基本上只是从数据库表中读取的记录数。
for each (Listener l in ls.Select(m.GetId()))
{
l.Start();
}
只有第一个线程被启动并运行,这是合乎逻辑的,因为阻止线程运行的唯一因素是永久循环。
但是如果它以这种方式运行;
std::vector<thread> listener_threads;
for each (Listener l in ls.Select(m.GetId()))
{
listener_threads.push_back(thread{ &Listener::Start, &l });
}
所有线程似乎都没有运行 - 没有一个侦听器回复任何请求。
所以问题是如何在C ++应用程序中运行不确定数量的线程。
答案 0 :(得分:0)
执行此操作的方法是首先收集向量中的所有侦听器实例。然后循环遍历此向量,创建另一个带有实际线程的向量。
// collect all the listeners into a vector
for (auto& m : rm.Select()) {
for (auto& l : ls.Select(m.GetId())) {
lvector.push_back(l);
}
}
// now create threads for each listener
for (auto& lstnr : lvector)
{
listener_threads.push_back(std::thread{ &Listener::Start, &lstnr });
}
// now join with this thread.
for (auto& t : listener_threads)
{
t.join();
}
由于我在每个线程的底部都有一段时间(真实) - 然后应用程序在继续监听所有必需的域时继续运行。
我认为范围可能有问题,因为lvector需要在for循环之外,并且它们都被添加。