我想将键/索引锁定在另一个地图中,如下所示:
std::map<int, boost::mutex> pointCloudsMutexes_;
pointCloudsMutexes_[index].lock();
但是,我收到以下错误:
/usr/include/c++/4.8/bits/stl_pair.h:113: error: no matching function for call to 'boost::mutex::mutex(const boost::mutex&)'
: first(__a), second(__b) { }
^
它似乎适用于std::vector
,但不适用于std::map
。我做错了什么?
答案 0 :(得分:4)
在C ++ 11之前的C ++中,std::map
的映射类型在调用operator[]
时必须是默认构造和可复制构造。但是,boost::mutex
明确地设计为不可复制,因为通常不清楚复制互斥锁的语义应该是什么。由于boost::mutex
无法复制,因此使用pointCloudsMutexes_[index]
插入此类值无法编译。
最好的解决方法是使用一些指向boost::mutex
的共享指针作为映射类型,例如:
#include <boost/smart_ptr/shared_ptr.hpp>
#include <boost/thread/mutex.hpp>
#include <map>
struct MyMutexWrapper {
MyMutexWrapper() : ptr(new boost::mutex()) {}
void lock() { ptr->lock(); }
void unlock() { ptr->unlock(); }
boost::shared_ptr<boost::mutex> ptr;
};
int main() {
int const index = 42;
std::map<int, MyMutexWrapper> pm;
pm[index].lock();
}
PS:C ++ 11删除了映射类型可复制构造的要求。
答案 1 :(得分:1)
Map需要一个拷贝构造函数,但遗憾的是boost::mutex
没有公共拷贝构造函数。 Mutex声明如下:
class mutex
{
private:
pthread_mutex_t m;
public:
BOOST_THREAD_NO_COPYABLE(mutex)
我认为矢量也不起作用,它应该有同样的问题。你可以push_back
boost::mutex
进入矢量吗?