草庐IT

Hash_class

全部标签

c++ - 一个类(class)的规模是多少?

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:EmptyclassinC++classClass1{charc;};classClass2{};Class1和Class2的大小是多少?在VC6中,我同时获得了1.有人可以解释一下吗?

c++ - 在 C++ 中重新定义模板 <class T>

我已经搜索并搜索了我的问题的解决方案,但似乎找不到。我正在使用Code::Blocks,但出现了模板类的重定义错误。这是我的“vectorAux.h”文件:#ifndefvectoraux_h#definevectoraux_h#include#include#includetemplatevoidremoveDup(std::vector&v);templateunsignedseqVectSearch(conststd::vector&v,unsignedfirst,unsignedlast,constT&target);templatevoidwriteVector(consts

c++ - SFINAE 专业类(class)

我想编写一个模板类,它使用SFINAE检查特征。正如我在那篇文章中读到的那样,类不能被“重载”:templateoverloadingandSFINAEworkingonlywithfunctionsbutnotclasses我写了下面的代码:classAA{public:usingTRAIT=int;};classBB{public:usingTRAIT=float;};templateclassX;templateclassX::value,int>::type>{public:X(){std::coutclassX::value,unsignedint>::type>{publi

c# - 父类(super class)构造函数中的虚拟化

我认为根据OOP的设计,虚拟化在父类(superclass)构造函数中不起作用。例如,考虑以下C#代码。usingSystem;namespaceProblem{publicclassBaseClass{publicBaseClass(){Console.WriteLine("Hello,World!");this.PrintRandom();}publicvirtualvoidPrintRandom(){Console.WriteLine("0");}}publicclassDescendent:BaseClass{privateRandomrandomValue;publicDes

c++ - <hash_set> 相等运算符在 VS2010 中不起作用

示例代码:std::hash_seths1;//alsoitrystd::unordered_set-sameeffectstd::hash_seths2;hs1.insert(15);hs1.insert(20);hs2.insert(20);hs2.insert(15);assert(hs1==hs2);hash_set不按照散列函数定义的某种顺序存储元素...为什么?请注意,此代码使用stdext::hash_set在VS2008中工作。 最佳答案 在VisualC++2010中,hash_set和unordered_set的

c++ - "virtual base class in the case of multilevel inheritance"有意义吗

考虑以下显示多级继承的示例代码:案例1:这里类derived1是通过虚拟继承从类base派生的,类derived2是从类派生的直接类derived1。classbase{};classderived1:virtualpublicbase{};classderived2:publicderived1{};Case2:与Case1相同,只是不涉及虚拟继承classbase{};classderived1:publicbase//novirtualinheritance{};classderived2:publicderived1{};假设我在这两种情况下都创建了derived2类的对象。C

c++ - 为什么我机器上的 hash_map 和 unordered_map 非常慢?

我用这段代码测试了它们(在VisualStudio2010sp1上):#include#include#include#include#includeintmain(){clock_ttime;intLOOP=(1my_map;std::unordered_mapmap_unordered_map;std::hash_mapmy_hash_map;time=clock();for(inti=0;i!=LOOP;++i){my_map[i]=i;}std::cout结果很奇怪:在调试中:map:0.289无序map:10.738HashMap:10.58按任意键继续。..在发布中:map

c++ - 对父类(super class)的引用

我想结合智能指针使用访问者模式,但编译器似乎无法检测子类并匹配适当的函数。我写了一个SSCE来说明问题:测试.hpp:classVisitor;classArea{public:virtualvoidvisit(constVisitor&visitor)=0;};classArea1:publicArea{public:virtualvoidvisit(constVisitor&visitor);};classArea2:publicArea{public:virtualvoidvisit(constVisitor&visitor);};classVisitor{public:virt

c++ - SFINAE 优雅地检查 "template template class"(在模板参数中)

如何在模板参数中检查模板模板类的类型?例子B和C是模板类。我想创建一个类D那可以是D或D.只有D有D::f().这是我的解决方法(demo)。它有效。#includeusingnamespacestd;classDummy{};templateclassB{};templateclassC{};templateclassBC>classD{//f()isinstantiatedonlyif"BC"=="B"public:template>statictypenamestd::enable_if>::value,void>::typef(){}//^#1};intmain(){D::f(

c++ - hash_map : why it defines less, 而不是 equal_to

C++,使用VisualStudio2010。关于为什么hash_map的用户定义特征的问题实际上需要总排序。我有一个简单的结构,比如说FOO,它只有一些整数。我想使用hash_map,这是一个哈希表,其键无序,用于存储FOO的结构。.我只需要快速搜索它的关联值,所以这是一个正确的选择:hash_map.但是,我需要为FOO实现自己的哈希函数和一些比较函数.这是hash_map的定义,摘自MSDN:template>,classAllocator=allocator>>classhash_map原来我需要实现hash_compare仿函数:template>classhash_comp