STD::Lock 的友元函数定义和替代提升函数
friend function definition and alternative boost function of std::lock
class some_big_object;
bool operator<(some_big_object& lhs,some_big_object& rhs);
class X
{
private:
some_big_object some_detail;
mutable std::mutex m;
public:
X(some_big_object const& sd):some_detail(sd){}
friend bool operator<(X const& lhs, X const& rhs) #1
{
if(&lhs == &rhs)
return false;
std::lock(lhs.m,rhs.m); #2
std::lock_guard<std::mutex> lock_a(lhs.m,std::adopt_lock);
std::lock_guard<std::mutex> lock_b(rhs.m,std::adopt_lock);
return lhs.some_detail<rhs.some_detail;
}
};
问题 1>这是我第一次看到在类范围内定义 friend 函数。合法吗?
问题2>std::lock
的替代升压功能是什么?
我看到了以下用法:
boost::unique_lock<MutexType1> l1(m1);
boost::unique_lock<MutexType2> l2(m2,boost::try_to_lock);
if(!l2)
{
return 1;
}
也许有点晚了,但boost
中有完全相同的函数(标准函数可能来自那里(。虽然它们还不是变异的。
你可以在这里找到它们。
boost::lock(lhs.m,rhs.m);
boost::lock_guard<Mutex> lock_a(lhs.m,boost::adopt_lock);
boost::lock_guard<Mutex> lock_b(rhs.m,boost::adopt_lock);
boost::mutex m;
boost::lock(m); //or unlock
m.lock(); //or unlock again
boost::lock_guard<boost::mutex> lock(m);
应该是提升语法。据我所知,boost::mutex 和 std::mutex 在书写:)上几乎相同
相关文章:
- 不同翻译单元中不可重载的非内联函数定义
- Visual Studio中的函数声明和函数定义问题
- 编写代码时C++出现错误:错误 1 错误 C2601:'circle':本地函数定义是非法的
- 具有enable_if外部类原型的模板类构造函数定义
- 类的前向声明之后的类成员函数定义,在类声明之前
- 为函数定义符号不明确的指针参数
- C++模板专用化 - 无法匹配函数定义
- 错误:在第 6 行'{'标记之前,此处不允许使用函数定义
- 找不到 #define 的函数定义
- 根据类型特征更改函数定义?
- 将抽象基类中的所有纯虚函数定义为 varaidaic 模板
- 命名空间更改函数定义
- "Type&"与C++函数定义中的"Type*"
- C++:为什么允许在另一个函数中声明函数,而不允许在函数定义中声明?
- 如何从 C++ 中的现有模板函数定义新函数
- 私有在函数定义/实现的返回值范围内是什么意思 (c++)?
- 越界成员函数定义是否需要一个完全限定的类名,直到全局范围
- 为什么c++允许成员函数定义中实例的私有成员访问
- Qt基类函数定义
- C++函数定义中参数列表后面额外一对括号的含义