Circular_buffer dalla libreria boost non è thread-safe. Quindi ho spostato l'oggetto boost :: circular_buffer in una classe come mostrato di seguito. L'esclusione reciproca tra i thread viene raggiunta (credo) utilizzando variabili condizionali, un mutex e un'acquisizione/rilascio di blocco. Questo thread di implementazione è sicuro?Implementazione sicura del buffer circolare
#include <boost/thread/condition.hpp>
#include <boost/thread/mutex.hpp>
#include <boost/thread/thread.hpp>
#include <boost/circular_buffer.hpp>
// Thread safe circular buffer
template <typename T>
class circ_buffer : private boost::noncopyable
{
public:
typedef boost::mutex::scoped_lock lock;
circ_buffer() {}
circ_buffer(int n) {cb.set_capacity(n);}
void send (T imdata) {
lock lk(monitor);
cb.push_back(imdata);
buffer_not_empty.notify_one();
}
T receive() {
lock lk(monitor);
while (cb.empty())
buffer_not_empty.wait(lk);
T imdata = cb.front();
cb.pop_front();
return imdata;
}
void clear() {
lock lk(monitor);
cb.clear();
}
int size() {
lock lk(monitor);
return cb.size();
}
void set_capacity(int capacity) {
lock lk(monitor);
cb.set_capacity(capacity);
}
private:
boost::condition buffer_not_empty;
boost::mutex monitor;
boost::circular_buffer<T> cb;
};
Modifica Questa è ora una classe template, che accetta un oggetto di qualsiasi tipo (non solo cv::Mat
oggetto).
Sembra che si adatterebbe meglio su [CodeReview] (http://codereview.stackexchange.com/). –
Perdona la mia domanda stupida, ma dove è necessario un buffer circolare sicuro per thread? In tutti i punti in cui ho mai usato un buffer circolare, sarebbe stato un brutto errore accedervi da più thread come questo. Quindi, solo per curiosità, qual è il tuo caso d'uso per questo? – LiKao
@LiKao Lo uso per afferrare fotogrammi dalle telecamere di rete in MATLAB, vedere il mio post precedente http://stackoverflow.com/questions/9472880/how-to-implement-a-circular-buffer-of-cvmat-objects-opencv . Come ti avvicineresti a questo? – Alexey