Quiero eliminar elemento de la cola con valor específico. ¿Cómo hacer tal cosa? (Estoy tratando de crear una mezcla simultánea de mapa y la cola y en la actualidad trato de aplicar en this answer)¿Es posible eliminar el elemento de cola por valor?
Así que actualmente tienen tal código:
#ifndef CONCURRENT_QUEUED_MAP_H
#define CONCURRENT_QUEUED_MAP_H
#include <map>
#include <deque>
#include <boost/thread.hpp>
#include <boost/thread/locks.hpp>
template <class map_t_1, class map_t_2>
class concurrent_queued_map
{
private:
std::map<map_t_1, map_t_2> _ds;
std::deque<map_t_1> _queue;
mutable boost::mutex mut_;
public:
concurrent_queued_map() {}
map_t_2 get(map_t_1 key) {
boost::mutex::scoped_lock lock(mut_);
return _ds[key];
}
map_t_1 put(map_t_1 key, map_t_2 value) {
boost::mutex::scoped_lock lock(mut_);
_ds.insert(std::pair<map_t_1, map_t_2>(key,value));
_queue.push_back(key);
return key;
}
map_t_2 get_last(map_t_1 key) {
boost::mutex::scoped_lock lock(mut_);
const map_t_1 k = _queue.front();
return _ds[k];
}
void remove_last(map_t_1 key) {
boost::mutex::scoped_lock lock(mut_);
const map_t_1 k = _queue.front();
_ds.erase(k);
_queue.pop_front();
}
void remove(map_t_1 key) {
boost::mutex::scoped_lock lock(mut_);
_queue.erase(std::remove(_queue.begin(), _queue.end(), key), _queue.end());
_ds.erase(k);
}
int size() {
boost::mutex::scoped_lock lock(mut_);
return _ds.size();
}
};
#endif // CONCURRENT_QUEUED_MAP_H
Entonces, ¿qué voy a hacer? ¿Cómo eliminar de la cola por valor? ¿O thare es cualquier componente STL o Boost que sea similar a la cola? ¿Quiere decir que tendría .front()
, pop_front();
y push_back(key);
y también admite la búsqueda y borrado por valor?
¿Puede expresar su pregunta de forma más clara y sucinta? Una cola no tiene "claves", por lo que su pregunta no tiene sentido; es un contenedor de secuencia que solo tiene * valores *. –