草庐IT

hash_initialized

全部标签

c++ - `constexpr` 变量 "used in its own initializer": Clang vs. GCC

这个问题似乎与anexistingone有关,但我不明白theanswerthere中提供的“可移植解决方法”(涉及constautothis_=this;)而且我认为下面的例子更容易理解。我正在使用以下C++17代码片段(livedemo):#includestructTest{constchar*name_{nullptr};constTest*src_{nullptr};constexprTest(constchar*name)noexcept:name_{name}{}constexprTest(constTest&src)noexcept:src_{&src}{name_=s

c++ - 错误 C2536 : cannot specify explicit initializer for arrays in Visual Studio 2013 的解决方法

下面的代码不能用VisualStudio2013编译,而它应该:classA{A():m_array{0,1,2}{}//errorC2536:'A::A::m_array':cannotspecifyexplicitinitializerforarraysprivate:intm_array[3];};参见bugreport了解更多详情。有哪些可能的解决方法? 最佳答案 如评论所述,您可以尝试此解决方法。classA{A():m_array({0,1,2}){}private:std::arraym_array;};似乎VS201

c++ - 什么语言规则允许 C++11 推断这是一个 initializer_list 对?

在C++11中,初始化std::map似乎是合法的如下:std::mapmyMap={{"One",1},{"Two",2},{"Three",3}};直觉上,这是有道理的——大括号括起来的初始化器是一个字符串对列表,std::map::value_type是std::pair(可能具有一些const资格。但是,我不确定我是否理解此处的输入方式。如果我们在这里去掉变量声明,只用大括号括起来的初始化器,编译器就不会知道它正在查看std::initializer_list>。因为它不知道括号对代表std::pair秒。因此,编译器似乎以某种方式推迟了将类型分配给大括号括起来的初始化程序的行

c++ - tr1::hash 用于 boost::thread::id?

我开始使用unordered_set来自tr1的类(class)命名空间以boost对普通(基于树的)STL的访问map.但是,我想在boost(boost::thread::id)中存储对线程ID的引用,并意识到这些标识符的API非常不透明,您无法清楚地获得它的哈希值。令人惊讶的是,boost实现了tr1的部分内容(包括hash和unordered_set),但它没有定义能够散列线程ID的散列类。查看boost::thread::id的文档我发现线程ID可以输出到流中,所以我的散列解决方案是这样的:structboost_thread_id_hash{size_toperator()

gcc 4.8.1 : list-initialization for copy constructor doesn't work 中的 C++11

我鼓励这个问题:如果我有classA{public:};intmain(){Aa{};Ab{a};}gcc给出:moves.cc:Infunction‘intmain()’:moves.cc:15:7:error:toomanyinitializersfor‘A’Ab{a};但是当我使用Ab(a)而不是Ab{a}时,所有编译都正确。如果我声明默认构造函数,它也会编译。为什么会这样? 最佳答案 该类是一个聚合,因此列表初始化将执行聚合初始化,并且不会考虑隐式声明的构造函数。因为没有数据成员,所以只有空列表可以是有效的聚合初始化器。Bu

c++ - 如何摆脱 g++ hash_map 弃用警告?

当我编译我正在编写的使用hash_map的c++应用程序时,我在g++4.3.2上收到此警告:您正在使用已弃用的header。要消除此警告,请使用ANSI标准头文件或使用hte-Wno-deprecated编译器标志。9>#include什么include取代了它?我在谷歌上搜索了一段时间,除了遇到类似问题但没有解决方案的人之外找不到任何东西。 最佳答案 我的第一个Google搜索“g++hash_mapdeprecated”将我带到了apage其中包括要使用的东西列表,而不是已弃用的header和类。对于hash_map,列表建议

OpenCV #以图搜图:感知哈希算法(Perceptual hash algorithm)的原理与实验

1.介绍感知哈希算法(PerceptualHashAlgorithm,简称pHash)是哈希算法的一种,主要用来做相似图片的搜索工作。 2.原理感知哈希算法(pHash)首先将原图像缩小成一个固定大小的像素图像,然后将图像转换为灰度图像,通过使用离散余弦变换(DCT)来获取频域信息。然后,根据DCT系数的均值生成一组哈希值。最后,利用两组图像的哈希值的汉明距离来评估图像的相似度。魔法:概括地讲,感知哈希算法一共可细分八步:缩小图像:将目标图像缩小为一个固定的大小,通常为32x32像素。作用是去除各种图像尺寸和图像比例的差异,只保留结构、明暗等基本信息,目的是确保图像的一致性,降低计算的复杂度。

c++ - 静态 C++ 映射初始化错误 C2552 : non-aggregates cannot be initialized with initializer list

我正在尝试使用以下代码在header中初始化map,但它一直在标题中显示错误。我正在使用C++11,所以这应该是可能的,对吧?typedefstd::map>AnimationSpeedMap;AnimationSpeedMapAnimationSpeeds={{NPCAnimation::WALK,{{Direction::LEFT,sf::milliseconds(100)},{Direction::RIGHT,sf::milliseconds(100)},{Direction::UP,sf::milliseconds(200)},{Direction::DOWN,sf::mill

c++ - 为什么不首选 std::initializer_list 转换?

考虑这个片段:#include#includevoidf(std::vector){std::coutLiveonColiru如果你运行它,你可以看到f(int)重载是首选,即使std::vector有一个std::initializer_listconstructor(见#8)。问题:为什么首选将{42}转换为int(而不是转换为std::vector,因为{42}是一个std::initializer_list)? 最佳答案 在重载决议中,当考虑implicitconversionsequenceinlist-initializ

c++ - 对于构造函数,我如何在可变参数模板与 std::initializer_list 之间进行选择?

在c++11的当前状态下(比如gcc4.7.2),我应该如何选择使用variadic-template或std::initializer_list我什么时候需要一个可以接受可变参数的构造函数? 最佳答案 可变参数模板允许您提供不同类型的参数,而std::initializer_list是用参数类型模板化的。这意味着列表中所有元素的类型必须相同(或可转换为基础类型,但不允许缩小转换)。根据这是否适合您,您可以选择其中之一。此外,如果您需要完美转发,可变参数模板通常是默认选择,因为语法形式T&&可以绑定(bind)到左值引用和右值引用,