2009-03-07 7 views
1

sur linux, gcc 4.3, la compilation d'une classe avec boost :: mise en œuvre de fil et mutex/variables de condition que je reçois l'erreur étrange suivante, apparemment en raison de taper des conflits avec la bibliothèque de threads Posix:boost erreur du compilateur de fil avec GCC

*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 a lieu dans le condition.hpp de boost, dans

if (!lock) 
    throw lock_error(); 

J'utilise Boost 1.38.0, sous Windows, je ne trouve pas de problème. Toute aide est appréciée!

Répondre

3

Vous devez attendre sur le bufferLock, pas m_mutex:

while (!m_bStop) 
    m_change.wait(bufferLock); 

Condition<>::wait() prend un ScopedLock en tant que paramètre, pas Mutex.

+0

C'est vrai, mais il ne résout pas le problème, l'erreur du compilateur reste –

+0

Oh, cela résout le problème, mon erreur! Je vous remercie –

Questions connexes