草庐IT

Duck-typing

全部标签

c++ - std::common_type 应该使用 std::decay 吗?

给定类型A,B,我关心std::common_type的确切定义,不考虑可变参数std::common_type对于任意类型A....所以让usingT=decltype(true?std::declval():std::declval());usingC=std::common_type;现在,根据一些消息来源,我发现了以下关系(为简洁起见,跳过typename):cppreference.com:C::type=std::decay::typecplusplus.com:C::type=TGCC4.8.1实现:C::type=std::decay::type如果T有效,否则C不包含

c++ - 错误 : called object type 'int' is not a function or function pointer

我在这里写了一个快速排序:voidswap(int&a,int&b);intmid(intlo,inthi);//Myquicksortimplementationvoidsort(intvec[],intlo,inthi){intmid;if(hi>lo){inti=lo+1;intj=hi;intp=mid(lo,hi);swap(vec[lo],vec[p]);mid=vec[lo];while(i=mid);swap(vec[i],vec[j]);}}i++;swap(vec[lo],vec[i]);sort(vec,lo,i);sort(vec,j,hi);}}voidswa

c++ - 错误 : called object type 'int' is not a function or function pointer

我在这里写了一个快速排序:voidswap(int&a,int&b);intmid(intlo,inthi);//Myquicksortimplementationvoidsort(intvec[],intlo,inthi){intmid;if(hi>lo){inti=lo+1;intj=hi;intp=mid(lo,hi);swap(vec[lo],vec[p]);mid=vec[lo];while(i=mid);swap(vec[i],vec[j]);}}i++;swap(vec[lo],vec[i]);sort(vec,lo,i);sort(vec,j,hi);}}voidswa

c++ - 错误 "C++ requires a type specifier for all declarations whilst defining methods"

我对C++比较陌生(所以请尽量保持简单的答案!),我不明白为什么会出现错误:C++需要所有声明的类型说明符同时定义方法。我正在尝试编写一个简单的程序来逐行读取文本文件,将值存储到数组中。但是,当我尝试在.cpp文件中声明方法时遇到问题。请在下面找到代码。StringList.h#ifndefStringListH#defineStringListH#include#includeclassStringList{public:StringList();~StringList();voidPrintWords();private:size_tnumberOfLines;std::vecto

c++ - 错误 "C++ requires a type specifier for all declarations whilst defining methods"

我对C++比较陌生(所以请尽量保持简单的答案!),我不明白为什么会出现错误:C++需要所有声明的类型说明符同时定义方法。我正在尝试编写一个简单的程序来逐行读取文本文件,将值存储到数组中。但是,当我尝试在.cpp文件中声明方法时遇到问题。请在下面找到代码。StringList.h#ifndefStringListH#defineStringListH#include#includeclassStringList{public:StringList();~StringList();voidPrintWords();private:size_tnumberOfLines;std::vecto

c++ - 为什么顺序容器同时具有 size_type 和 difference_type?

vector两者都有vector::size_type和vector::difference_type.从size_type开始,两者似乎都没有必要存在。保证能够保存与vector的最大元素数一样大的值。可能包含在给定的系统上,并且在任何有效的用例中,difference_type必须小于或等于最大元素数,即顺序容器中两个元素之间的距离永远不会大于顺序容器可以包含的最大元素数。有人可以举个例子说明两者之间有什么区别吗? 最佳答案 container::difference_type存在是因为对于某些序列容器,您可以减去迭代器。该减法

c++ - 为什么顺序容器同时具有 size_type 和 difference_type?

vector两者都有vector::size_type和vector::difference_type.从size_type开始,两者似乎都没有必要存在。保证能够保存与vector的最大元素数一样大的值。可能包含在给定的系统上,并且在任何有效的用例中,difference_type必须小于或等于最大元素数,即顺序容器中两个元素之间的距离永远不会大于顺序容器可以包含的最大元素数。有人可以举个例子说明两者之间有什么区别吗? 最佳答案 container::difference_type存在是因为对于某些序列容器,您可以减去迭代器。该减法

c++ - std::map 是如何实现的,所以它可以要求它的 key_type 具有可比性?

这是我对Box类的实现:classBox{friendostream&operator这是测试代码:intmain(){Boxb1(3,2),b2(2,1),b3(0,9);mapbmap;bmap.insert(pair(b1,10));bmap.insert(pair(b2,10));bmap.insert(pair(b3,10));for(map::iteratoriter=bmap.begin();iter!=bmap.end();++iter){coutfirst如果我删除Box类上operator我有一些Java经验,我知道在类似的情况下我只需要让Box实现Comarabl

c++ - std::map 是如何实现的,所以它可以要求它的 key_type 具有可比性?

这是我对Box类的实现:classBox{friendostream&operator这是测试代码:intmain(){Boxb1(3,2),b2(2,1),b3(0,9);mapbmap;bmap.insert(pair(b1,10));bmap.insert(pair(b2,10));bmap.insert(pair(b3,10));for(map::iteratoriter=bmap.begin();iter!=bmap.end();++iter){coutfirst如果我删除Box类上operator我有一些Java经验,我知道在类似的情况下我只需要让Box实现Comarabl

C++: "vector<int>::size_type variable"- 以这种方式声明有什么意义?

我认为这是一个非常基本的问题,但我无法弄清楚。我习惯于在C++中使用数组,但我现在开始学习vector。我正在编写测试代码,遇到了一个问题。首先,这是我制作的代码:#include#include#includeusingnamespacestd;intmain(){vectorscore(10);for(vector::size_typei=0;i>score[i];}doubletotal=accumulate(score.begin(),score.end(),0);cout在for第9行中的句子,我声明i作为vector::size_type类型(因为有人告诉我这样做)。我用i