草庐IT

different-size

全部标签

c++ - 错误 C2228 : left of '.size' must have class/struct/union

我在调用vector的size()时遇到此编译器错误。为什么?#include#include#include#include#include#includeusingnamespacestd;classVertex{floatfirstValue;floatsecondValue;floatthirdValue;Vertex(floatfirst,floatsecond,floatthird){firstValue=first;secondValue=second;thirdValue=third;}};intmain(){cout>actualLine;istringstreama

c++ - std::size_t vs size_t vs std::string::size_type

size_t在哪里什么时候我什么都没有?总是假设size_t是否合理?==std::size_t?什么时候应该使用size_type在std容器(string::size_type、vector::size_type等)? 最佳答案 Wheredoessize_tcomefromwhenIdon'thaveanythingincludedinanemptyproject?如果您没有包含任何内容,则无法使用size_t.它在中定义(也可能在中,如果您的该header版本将定义放在全局命名空间以及std中)。Isitreasonable

c++ - std::size_t vs size_t vs std::string::size_type

size_t在哪里什么时候我什么都没有?总是假设size_t是否合理?==std::size_t?什么时候应该使用size_type在std容器(string::size_type、vector::size_type等)? 最佳答案 Wheredoessize_tcomefromwhenIdon'thaveanythingincludedinanemptyproject?如果您没有包含任何内容,则无法使用size_t.它在中定义(也可能在中,如果您的该header版本将定义放在全局命名空间以及std中)。Isitreasonable

c++ - 为什么 back_insert_iterator/front_insert_iterator/insert_iterator 的 value_type/difference_type/pointer/reference 都是 void?

在我的项目中,我想将流拆分为一些给定类型的值,所以我实现了一个模板函数templateTOutputIterSplitSpace(std::istream&IS,TOutputIterresult){TElemelem;while(IS>>elem){*result=elem;++result;}returnresult;}我认为这很尴尬,因为我必须在调用时明确给出TElem的类型。例如,我必须写:std::vectorv;SplitSpace(std::cin,back_inserter(v));//IwanttoittobeSplitSpace(std::cin,back_inse

c++ - 为什么 back_insert_iterator/front_insert_iterator/insert_iterator 的 value_type/difference_type/pointer/reference 都是 void?

在我的项目中,我想将流拆分为一些给定类型的值,所以我实现了一个模板函数templateTOutputIterSplitSpace(std::istream&IS,TOutputIterresult){TElemelem;while(IS>>elem){*result=elem;++result;}returnresult;}我认为这很尴尬,因为我必须在调用时明确给出TElem的类型。例如,我必须写:std::vectorv;SplitSpace(std::cin,back_inserter(v));//IwanttoittobeSplitSpace(std::cin,back_inse

c++ - 如何在不破坏代码的情况下正确修复 "zero-sized array in struct/union"警告(C4200)?

我正在将一些代码集成到我的库中。这是一个针对速度进行了优化的复杂数据结构,所以我尽量不要对其进行过多修改。集成过程进展顺利,实际上几乎完成(它编译)。一件事仍然困扰着我。我多次收到C4200警告:warningC4200:nonstandardextensionused:zero-sizedarrayinstruct/unionCannotgeneratecopy-ctororcopy-assignmentoperatorwhenUDTcontainsazero-sizedarray代码有效,但这个警告让我毛骨悚然(尤其是带有copy-ctor的部分)。由于这样声明的结构而出现警告:#

c++ - 如何在不破坏代码的情况下正确修复 "zero-sized array in struct/union"警告(C4200)?

我正在将一些代码集成到我的库中。这是一个针对速度进行了优化的复杂数据结构,所以我尽量不要对其进行过多修改。集成过程进展顺利,实际上几乎完成(它编译)。一件事仍然困扰着我。我多次收到C4200警告:warningC4200:nonstandardextensionused:zero-sizedarrayinstruct/unionCannotgeneratecopy-ctororcopy-assignmentoperatorwhenUDTcontainsazero-sizedarray代码有效,但这个警告让我毛骨悚然(尤其是带有copy-ctor的部分)。由于这样声明的结构而出现警告:#

c++ - 中缀 vs 前缀语法 : name lookup differences

C++中的运算符通常被认为是函数/方法的替代语法,尤其是在重载的上下文中。如果是这样,下面的两个表达式应该是同义词:std::cout在实践中,第二条语句会导致以下错误:callofoverloaded‘operator像往常一样,这样的错误信息伴随着一个可能的候选列表,它们是:operator&__out,char__c)operator&__out,char__c)operator&__out,signedchar__c)operator&__out,unsignedchar__c)这样的错误至少引发了两个问题:这两个语句有何不同(在名称查找方面)?为什么operator&__ou

c++ - 中缀 vs 前缀语法 : name lookup differences

C++中的运算符通常被认为是函数/方法的替代语法,尤其是在重载的上下文中。如果是这样,下面的两个表达式应该是同义词:std::cout在实践中,第二条语句会导致以下错误:callofoverloaded‘operator像往常一样,这样的错误信息伴随着一个可能的候选列表,它们是:operator&__out,char__c)operator&__out,char__c)operator&__out,signedchar__c)operator&__out,unsignedchar__c)这样的错误至少引发了两个问题:这两个语句有何不同(在名称查找方面)?为什么operator&__ou

c++ - 抛出异常后我可以信任 vector::size 吗?

我试图了解异常如何影响std::vector。更准确地说,我想在抛出内存不足异常时检查vector的大小。我的意思是这样的:std::vectorv;try{for(unsignedinti=0;i这是一个好方法还是我应该使用我的自变量来跟踪vector的大小? 最佳答案 来自thedocumentationforstd::vector::push_back:Ifanexceptionisthrown(whichcanbeduetoAllocator::allocate()orelementcopy/moveconstructor/