Erreur du compilateur de thread boost avec GCC
-
05-07-2019 - |
Question
sur linux, gcc 4.3, compilant une classe avec l’implémentation de boost :: thread et des variables mutexes / condition j’obtiens l’erreur étrange suivante, apparemment en raison de conflits de types avec la bibliothèque de threads posix:
*Compiling: filter.cpp
/usr/include/boost/thread/condition.hpp: In member function »void boost::condition::wait(L&) [with L = boost::mutex]«:
/host/.../filter.cpp:68: instantiated from here
/usr/include/boost/thread/condition.hpp:90: Error: no match für »operator!« in »!lock«*
*/usr/include/boost/thread/condition.hpp:90: Notice: candidates are: operator!(bool) <built in>*
*/usr/include/boost/thread/mutex.hpp:66: Error: »pthread_mutex_t boost::mutex::m_mutex« is private
/usr/include/boost/thread/condition.hpp:93: Error: in this context*
Le code est:
void CFilter::process( CData **s )
{
boost::mutex::scoped_lock bufferLock(m_mutex);
while (!m_bStop)
m_change.wait(bufferLock); //<- line 68
// ... further processing
}
avec la déclaration de classe
#include <boost/shared_ptr.hpp>
#include <boost/bind.hpp>
#include <boost/thread/condition.hpp>
#include <boost/thread/thread.hpp>
#include <boost/thread/mutex.hpp>
class CFilter
{
// ...
boost::shared_ptr<boost::thread> m_thread;
boost::mutex m_mutex;
boost::condition m_change;
// ...
process( CData **s );
}
L'erreur de l'opérateur se produit dans la condition de boost.hpp, dans
if (!lock)
throw lock_error();
J'utilise Boost 1.38.0, sous Windows, je ne trouve aucun problème. Toute aide est appréciée!
La solution
Vous devez attendre le bufferLock
, pas m_mutex
:
while (!m_bStop)
m_change.wait(bufferLock);
Condition < > :: wait () prend un ScopedLock
en tant que paramètre, pas un Mutex
.
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow