- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有这样的代码:
#include <memory>
#include <map>
struct element {
std::map<std::weak_ptr<int>, int> weights;
bool operator<(const element &a) const { return this->weights < a.weights; }
};
int main() { return 0; }
我想比较这个类的两个实例,但是我得到了编译器错误:
/usr/include/c++/4.8/bits/stl_pair.h: In instantiation of ‘constexpr bool std::operator<(const std::pair<_T1, _T2>&, const std::pair<_T1, _T2>&) [with _T1 = const std::weak_ptr<int>; _T2 = int]’:
/usr/include/c++/4.8/bits/stl_pair.h:221:24: error: no match for ‘operator<’ (operand types are ‘const std::weak_ptr<int>’ and ‘const std::weak_ptr<int>’)
{ return __x.first < __y.first
/usr/include/c++/4.8/bits/stl_pair.h:222:23: error: no match for ‘operator<’ (operand types are ‘const std::weak_ptr<int>’ and ‘const std::weak_ptr<int>’)
|| (!(__y.first < __x.first) && __x.second < __y.second); }
/usr/include/c++/4.8/bits/stl_pair.h:222:65: error: body of constexpr function ‘constexpr bool std::operator<(const std::pair<_T1, _T2>&, const std::pair<_T1, _T2>&) [with _T1 = const std::weak_ptr<int>; _T2 = int]’ not a return-statement
|| (!(__y.first < __x.first) && __x.second < __y.second); }
看到no match for operator
,我添加了以下代码,但没有帮助。
// from boost::weak_ptr
template<typename T, typename U>
bool operator<(const std::weak_ptr<T> &a, const std::weak_ptr<U> &b)
{
return a.owner_before(b);
}
当我尝试以下操作时,错误仍然存在:
constexpr
任何该运营商;std::map<std::weak_ptr<int>, int, std::owner_less<std::weak_ptr<int>>>
.我可以通过以下方式编译这段代码:
return true
;std::weak_ptr
,例如至 std::map<int, int>
;选项 1. 和 2. 只是为了测试,而不是一个选项; 3. 有可能,但我想了解为什么会出现此错误并尽可能使用标准库。根据我的理解,它应该编译:std::map
有一个 operator<
,它比较内部树,它应该比较 pairs<key, data>
,它比较了这对中的第一个和第二个元素,这至少在 operator<
的情况下应该有效。对于 weak_ptr
提供。
但它不起作用(至少不适用于 g++ 4.8.{1,2}),因此我的问题是:
maps
与 weak_ptr
作为关键?更新,使用std::lexicographical_compare
正如 KerrekSB 所建议的那样。
我正在尝试比较两个不同 map 。在下面的示例中,映射 m1 和 m2 具有相同的键,但使用此键存储不同的值。如果比较这两个映射,它们应该不相等,应该一个排在另一个之前。
#include <memory>
#include <map>
#include <iostream>
typedef std::owner_less<std::weak_ptr<int>> wp_less;
typedef std::map<std::weak_ptr<int>, int, wp_less> wp_map;
bool map_cmp(const wp_map &a, const wp_map &b)
{
return std::lexicographical_compare(
a.begin(), a.end(),
b.begin(), b.end(),
[]( std::pair<std::weak_ptr<int> const, int> const & p,
std::pair<std::weak_ptr<int> const, int> const & q) -> bool
{ return wp_less()(p.first, q.first); });
//{ return wp_less()(p.first, q.first)
// || ( ! (wp_less()(q.first, p.first)) && p.second < q.second); });
}
int main()
{
std::shared_ptr<int> sp_int(std::make_shared<int>(5));
std::weak_ptr<int> wp_int(sp_int);
wp_map m1, m2;
m1[wp_int] = 1;
m2[wp_int] = 2;
std::cout << "m1 < m2=" << map_cmp(m1, m2) << "\nm2 < m1=" << map_cmp(m2, m1);
return 0;
}
显示的输出表明两者相等:
m1 < m2=0
m2 < m1=0
但它们不是,通过使用注释比较,结果变成:
m1 < m2=1
m2 < m1=0
所以这给我留下了:
最佳答案
不要使用裸<
,而是使用 std::lexicographical_compare
算法,您可以为其提供自定义谓词,例如 std::owner_less
.
裸体<
运算符使用默认版本的字典顺序与 std::less
进行比较谓词,它不适用于弱指针。
有点啰嗦,给大家举个例子:
std::map<std::weak_ptr<int>, int, std::owner_less<std::weak_ptr<int>>> a, b;
return std::lexicographical_compare(
a.begin(), a.end(),
b.begin(), b.end(),
[](std::pair<std::weak_ptr<int> const, int> const & p,
std::pair<std::weak_ptr<int> const, int> const & q)
-> bool { return std::owner_less<std::weak_ptr<int>>()(p.first, q.first); });
在此示例中,表达式 a < b
等同于:
std::lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())
这是行不通的,因为这会尝试比较对,而这又会尝试将弱指针与 std::less<std::weak_ptr<int>>()
进行比较。 . (问题当然是算法使用 iterators 并且不知道各自容器中的比较器对象。一般来说,没有理由为什么两个具有相同值类型的映射甚至应该使用完全相同的比较器。)
您可以根据 owner_before
编写类似的内容如果你想要的话。之美std::owner_less
是它在同一次清洗中比较弱和共享指针。
关于c++ - 如何比较两个以 std::weak_ptr 为键的 std::maps?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20848708/
我正在开发一个小型图书馆,我需要做的一件事是让访问者访问一些数据并返回结果。 在一些较旧的 C++ 代码中,访问者需要声明一个 typedef return_type .例如,boost::stati
我正在尝试使用std:map类型的键和值制作std::any Visual Studio 2017 std::map m("lastname", "Ivanov"); std::cout (m["la
我已经在 C++ 的 map 中声明了一个集合为 std::map> .如何循环访问或打印设定值? 最佳答案 如果你知道如何迭代 std::map或 std::set单独地,您应该可以毫无问题地组合迭
如何循环? 我已经试过了: //----- code std::vector >::iterator it; for ( it = users.begin(); it != users.end();
我有两个用例。 A.我想同步访问两个线程的队列。 B.我想同步两个线程对队列的访问并使用条件变量,因为其中一个线程将等待另一个线程将内容存储到队列中。 对于用例 A,我看到了使用 std::lock_
我正在查看这两种类型特征的文档,但不确定有什么区别。我不是语言律师,但据我所知,它们都适用于“memcpy-able”类型。 它们可以互换使用吗? 最佳答案 不,这些术语不能互换使用。这两个术语都表示
我有以下测试代码,其中有一个参数 fS,它是 ofstream 的容器: #include #include #include #include int
这是这个问题的延续 c++ function ptr in unorderer_map, compile time error 我试图使用 std::function 而不是函数指针,并且只有当函数是
std::unordered_map str_bool_map = { {"a", true}, {"b", false}, {"c", true} }; 我们可以在此映射上使
我有以下对象 std::vector> vectorList; 然后我添加到这个使用 std::vector vec_tmp; vec_tmp.push_back(strDRG); vec_tmp.p
为什么 std::initializer_list不支持std::get<> , std::tuple_size和 std::tuple_element ?在constexpr中用得很多现在的表达式,
我有一个像这样定义的变量 auto drum = std::make_tuple ( std::make_tuple ( 0.3f , Ex
假设我有一个私有(private)std::map在我的类(class)里std::map 。我怎样才能将其转换为std::map返回给用户?我想要下面的原型(prototype) const std
假设我有一个私有(private)std::map在我的类(class)里std::map 。我怎样才能将其转换为std::map返回给用户?我想要下面的原型(prototype) const std
问题 我正在尝试将 lambda 闭包传递给 std::thread,它使用任意封闭参数调用任意封闭函数。 template std::thread timed_thread(Function&& f
我想创建一个模板类,可以容纳容器和容器的任意组合。例如,std::vector或 std::map ,例如。 我尝试了很多组合,但我必须承认模板的复杂性让我不知所措。我编译的关闭是这样的: templ
我有一个 std::vector>我将其分配给相同类型的第二个 vector 。 我收到这个编译器错误: /opt/gcc-8.2.0/include/c++/8.2.0/bits/stl_algob
有时候,我们有一个工厂可以生成一个 std::unique_ptr vector ,后来我们想在类/线程/你命名的之间共享这些指针。因此,最好改用 std::shared_ptr 。当然有一种方法可以
这个问题在这里已经有了答案: Sorting a vector of custom objects (14 个答案) 关闭 6 年前。 我创建了一个 vector vector ,我想根据我定义的参
我有三个类(class)成员: public: std::vector > getObjects(); std::vector > getObjects() const; privat
我是一名优秀的程序员,十分优秀!