Voglio rimuovere l'elemento dalla coda con un valore specifico. Come fare una cosa del genere? (Sto cercando di creare una miscela concomitante di mappa e di coda e attualmente cerco di implementare su this answer)È possibile rimuovere l'elemento coda per valore?
Così ho attualmente tale codice:
#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
Allora, cosa devo fare? Come rimuovere dalla coda in base al valore? Oppure thare è un componente STL o Boost che è uguale alla coda? Significa che avrebbe .front()
, pop_front();
e push_back(key);
e supporta anche la ricerca e cancellare in base al valore?
Puoi esprimere la tua domanda in modo un po 'più chiaro e conciso? Una coda non ha "chiavi", quindi la tua domanda non ha senso; è un contenitore di sequenza che ha solo * valori *. –