草庐IT

erase_all

全部标签

c++ - boost::filesystem::remove_all(path) 是如何工作的?

我正在尝试使用boost::filesystem::remove_all(path)从特定路径中删除所有目录、子目录和包含的文件。如果文件在另一个程序中打开,我还想显示一条错误消息。在这种情况下boost::filesystem::remove_all(path)会抛出异常吗?或者有其他方法可以实现吗? 最佳答案 这不适合发表评论,所以我发布为答案只需查看源代码:http://www.boost.org/doc/libs/1_55_0/libs/filesystem/src/operations.cppBOOST_FILESYSTE

c++ - C++中set的erase函数会改变其他元素的地址吗?

我有以下代码:settest;test.insert(key1);test.insert(key2);iter1=test.find(key1);iter2=test.find(key2);test.erase(iter1);我的问题是,如果key1被删除了,现在测试中是否可以用iter2引用key2?谢谢 最佳答案 是的,set的erase只会使指向被删除元素的迭代器无效(注意,这不一定适用于所有容器)。 关于c++-C++中set的erase函数会改变其他元素的地址吗?,我们在Sta

c++ - 为什么 VS2008 std::string.erase() 移动它的缓冲区?

我想逐行读取文件并捕获特定的输入行。为了获得最佳性能,我可以通过读取整个文件并使用指针迭代其内容来以低级方式执行此操作,但这段代码对性能并不关键,因此我希望使用更具可读性和类型安全性的std库样式实现。所以我有这个:std::stringline;line.reserve(1024);std::ifstreamfile(filePath);while(file){std::getline(file,line);if(line.substr(0,8)=="Whatever"){//Dosomething...}}虽然这不是性能关键代码,但我在解析操作之前调用了line.reserve(1

c++ - 在 erase-remove 习语中使用一元谓词的否定

考虑以下场景:boolis_odd(inti){return(i%2)!=0;}intmain(){//ignorethemethodofvectorinitializationbelow.//assumeC++11isnottobeused.std::vectorv1={0,1,2,3,4,5,6,7,8,9};std::vectorv2={0,1,2,3,4,5,6,7,8,9};//removesalloddnumbers,OKv1.erase(std::remove_if(v1.begin(),v1.end(),is_odd),v1.end());//removealleven

c++ - delete[] 是否适用于通用数组?如果是这样,为什么在其上使用 std::vector::erase 会导致释放内存时出错

我曾尝试使用圆形数组,因此最终编写了一个CircularArray类,并附上了代码。它使用数组的通用指针。当我尝试使用std::vector创建此类圆形数组的列表时,我在尝试对其使用删除时遇到了问题。我不明白为什么会这样,因为我认为析构函数和复制构造函数正常工作得很好。有人可以帮忙吗?代码:CircularArray类templateclassCircularArray{//Classdenotedby'T'isexpectedtohaveafunctionalassignmentoperator,i.e.operator=(constT&ext){}inplaceprotected:

c++ - "Bring all the zeros to the back of the array"面试挑战的良好 C++ 解决方案

我接受了一份Jr.开发工作的面试,他要求我编写一个程序,该程序接受一个整数数组并将零推到后面。这是约束条件(他一开始没有告诉我......就像在编程面试中经常发生的那样,我在解决问题的同时了解了问题的约束条件,哈哈):必须就地进行;不创建临时数组、新数组等。不必保留非零数字的顺序(我希望他一开始就告诉我)设置:intarr[]={0,-2,4,0,19,69};/*Transformarrto{-2,4,19,69,0,0}or{69,4,-2,19,0,0}oranythingthatpushesallthenonzerostothebackandkeepsallthenonzero

C++ std::set::erase 与 std::remove_if

此代码有VisualStudioerrorC3892。如果我将std::set更改为std::vector-它有效。std::seta;a.erase(std::remove_if(a.begin(),a.end(),[](intitem){returnitem==10;}),a.end());怎么了?为什么我不能将std::remove_if与std::set一起使用? 最佳答案 您不能使用std::remove_if()具有const的序列部分。std::set的序列元素由Tconst组成对象。事实上,我们昨天在标准C++委员会

c++ - 是否存在使用 catch all 子句 : catch (. ..) 的情况?

每次我看到catchall语句时:try{//somecode}catch(...){}它一直是一种滥用。反对使用cacheall子句的论点是显而易见的。它会捕获任何,包括操作系统生成的异常,例如访问冲突。由于异常处理程序不知道它在处理什么,在大多数情况下,异常将表现为模糊的日志消息或一些不连贯的消息框。所以catch(...)看起来天生就是邪恶的。但它仍然在C++中实现,其他语言(Java、C#)也实现了类似的机制。那么在某些情况下它的使用是合理的吗? 最佳答案 (1)声明将捕获操作系统异常是不正确的。您对“访问冲突”一词的使用背

c++ - pop_back() 是否真的使 std::vector 上的 *all* 迭代器无效?

std::vectorints;//...fillintswithrandomvaluesfor(std::vector::iteratorit=ints.begin();it!=ints.end();){if(*it此代码无效,因为调用pop_back()时,它无效。但我没有找到任何文档讨论std::vector::pop_back()中迭代器的失效。你有相关链接吗? 最佳答案 调用pop_back()删除vector中的最后一个元素,因此该元素的迭代器无效。pop_back()调用不会使最后一个元素之前的项目的迭代器无效,只有重

c++ - 对齐 : warning C4316 in all classes that have aligned members

今天我遇到了很多麻烦,因为我跟踪了一个非常隐蔽的腐败漏洞。我想如果我真的注意警告就不会那么难找到它,但由于找不到有关为什么弹出此特定警告的相关信息,我让它滑动了,这是一个错误。所以这是VisualStudio2013给我的有罪警告:warningC4316:objectallocatedontheheapmaynotbealigned16它是在通过const引用将align(16)临时传递给构造函数时生成的,如以下代码所示:classVector{};__declspec(align(16))classVectorA{};classShape{public:Shape(constVec