草庐IT

back-stack

全部标签

C++ vector push_back

将新对象元素推送到std::vector的正确方法是什么?我希望在vector中分配数据。这是否会将对象newradio复制到vector中,然后在newradio超出范围(例如,超出堆栈)时摆脱它?vectorm_radios;Radionewradio(radioNum);m_radios.push_back(newradio);然后当我释放包含m_radios的对象时,这会释放vector分配的所有内存吗? 最佳答案 std::vector管理自己的内存。这意味着,当调用vector的析构函数时,vector持有的内存被释放。

c++ vector.push_back 错误: request for member 'push_back' . ..,属于非类类型 'vector(char, allocator(char)) ()()'

我将Cygwin与GCC一起使用,最终我想将字rune件读入字符vector,并使用此代码#include#include#includeusingnamespacestd;intmain(intargc,char*argv[]){vectorstring1();string1.push_back('a');return0;}生成此编译时错误:main.cpp:Infunctionintmain(int,char**)':main.cpp:46:error:requestformemberpush_back'instring1',whichisofnon-classtypestd::v

c++ vector.push_back 错误: request for member 'push_back' . ..,属于非类类型 'vector(char, allocator(char)) ()()'

我将Cygwin与GCC一起使用,最终我想将字rune件读入字符vector,并使用此代码#include#include#includeusingnamespacestd;intmain(intargc,char*argv[]){vectorstring1();string1.push_back('a');return0;}生成此编译时错误:main.cpp:Infunctionintmain(int,char**)':main.cpp:46:error:requestformemberpush_back'instring1',whichisofnon-classtypestd::v

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++ - Valgrind 几乎对所有内容都给出错误(警告 : client switching stacks?)

我以某种方式破坏了内存,因为我的程序在随机位置崩溃而没有错误。我正在使用带有--leak-check=full的valgrind,使用-O0-g进行编译,它检测到的第一个问题是intmain()cout与==5089==Warning:clientswitchingstacks?SPchange:0x7ff0004f8-->0x7feb7de10==5089==tosuppress,use:--max-stackframe=4728552orgreater==5089==Invalidwriteofsize8==5089==at0x41E107:main(Dgn.cpp:2833)==

c++ - Valgrind 几乎对所有内容都给出错误(警告 : client switching stacks?)

我以某种方式破坏了内存,因为我的程序在随机位置崩溃而没有错误。我正在使用带有--leak-check=full的valgrind,使用-O0-g进行编译,它检测到的第一个问题是intmain()cout与==5089==Warning:clientswitchingstacks?SPchange:0x7ff0004f8-->0x7feb7de10==5089==tosuppress,use:--max-stackframe=4728552orgreater==5089==Invalidwriteofsize8==5089==at0x41E107:main(Dgn.cpp:2833)==

C++ STL 堆栈问题 : Why does pop() not throw an exception if the stack is empty?

如果堆栈为空且没有可弹出的内容,为什么std::stack::pop()不抛出异常?(我正在为我自己的代码设计一个专门的堆栈,并且想知道这种方法(需要手动检查堆栈是否为空)与抛出异常之间的权衡。我的猜测是,尽管C++支持异常处理,但它的运行时开销很小,因此,为了获得最佳性能,决定不在std::stack::pop中抛出异常)。 最佳答案 我认为pop()不必抛出异常的原因与效率或性能无关,而是与异常有关。正如所争论的elsewhere:SGIexplanation:http://www.sgi.com/tech/stl/stack.

C++ STL 堆栈问题 : Why does pop() not throw an exception if the stack is empty?

如果堆栈为空且没有可弹出的内容,为什么std::stack::pop()不抛出异常?(我正在为我自己的代码设计一个专门的堆栈,并且想知道这种方法(需要手动检查堆栈是否为空)与抛出异常之间的权衡。我的猜测是,尽管C++支持异常处理,但它的运行时开销很小,因此,为了获得最佳性能,决定不在std::stack::pop中抛出异常)。 最佳答案 我认为pop()不必抛出异常的原因与效率或性能无关,而是与异常有关。正如所争论的elsewhere:SGIexplanation:http://www.sgi.com/tech/stl/stack.

c++ - 将 std::stack .pop() 方法的结果存储到变量中

我想做以下事情:std::stacks;inth=0;s.push(2);h=s.pop();例如让h保持值2。当我尝试我的方法时,我得到“voidvaluenotignoredasithouldbe”。这不是.pop()方法的意图吗?执行此操作的首选方法是什么? 最佳答案 标准库容器将top()和pop()分开:top()返回对顶部元素的引用,而pop()移除顶部元素。(对于back()/pop_back()等类似)。这种分离是有充分理由的,而不是让pop删除顶部元素并返回它:C++的一个指导原则是您无需为你不需要什么。单个函数别