草庐IT

Initializer-list

全部标签

c++ - 删除 std::list::iterator 不会使迭代器无效并销毁对象吗?

为什么下面打印2?listl;l.push_back(1);l.push_back(2);l.push_back(3);list::iteratori=l.begin();i++;l.erase(i);cout我知道erase返回什么,但我想知道为什么这样可以?或者它是未定义的,还是取决于编译器? 最佳答案 是的,这是未定义的行为。您正在取消引用一种野指针。在erase之后,您不应该使用i的值。是的,erasedestructs指向的对象。但是,对于POD类型,销毁不会执行任何操作。erase不会为被删除的迭代器分配任何特殊的“空”

c++ - 错误 : initializer fails to determine size of ‘K’

我在行中收到错误“初始化器无法确定‘K’的大小”intK[]=newint[Vertices->total];如何解决? 最佳答案 改变intK[]=newint[Vertices->total];到int*K=newint[Vertices->total];第一个是Java创建数组的方法,其中K是对整数数组的引用。但是在C++中,我们需要让K成为一个指向整数类型的指针。 关于c++-错误:initializerfailstodeterminesizeof‘K’,我们在StackOver

c++ - std::shuffle 不能用 std::list 编译

我正在尝试打乱一些生成元素的列表。这是代码:std::default_random_enginegenerator(10);std::listlist(10);intn=0;std::generate(list.begin(),list.end(),[&]{returnn++;});std::shuffle(list.begin(),list.end(),generator);它不编译。以下是错误:/include/c++/v1/algorithm:3059:34:Invalidoperandstobinaryexpression('std::__1::__list_iterator'

C++ list<T>::iterator 不能在派生类模板中使用

g++编译器给出了这个错误:expected`;'在“它”之前templateclassmyList:publicstd::list{public:voidfoo(){std::list::iteratorit;//compilererrorasabovementioned,why???}};谢谢。 最佳答案 在g++中。每当在模板中看到错误时:error:expected';'before'it'怀疑你需要一个类型名:typenamestd::list::iteratorit;当您在模板中声明了一个依赖于一个或多个模板参数的新类型

c++ - 从 std::list 中移除具有特定值的元素

我需要从std::list中删除具有特定值的元素。随着list我使用了remove()方法。现在我有list所以我想我应该使用remove_if()但它的谓词只需要一个参数-要测试的元素。如何编写函数foo(constCMyClass&Bad)从列表中删除所有等于Bad的元素?谢谢附言structCMyClass{void*Ptr;intVar;}boolis_equal(constCMyClass&A,constCMyClass&B){if(A.Ptr==B.PrtandA.Var==B.Var)returntrue;elsereturnfalse;} 最

c++ - 为什么初始化列表初始化需要堆分配数组的大小?

虽然我会写intn[]{1,2,3};我不会写int*m=newint[]{1,2,3};应该是int*m=newint[3]{1,2,3};这是什么原因? 最佳答案 请记住,new实际上是C++中的运算符。这是因为new操作符是如何定义的;也就是说,它需要明确地将请求的内存大小作为输入参数。因此,它不会由初始化列表成员的数量推导出来。 关于c++-为什么初始化列表初始化需要堆分配数组的大小?,我们在StackOverflow上找到一个类似的问题: https

c++ - 如何通过 C++ 可执行文件中的 list 启用 "Long Path Aware"行为?

我正在尝试关注Microsoftdocumentation解除Windows10下API中的MAX_PATH文件路径限制。它说:Youcanalsoenablethenewlongpathbehaviorperappviathemanifest:true所以,第一个问题。是否可以在VisualStudio2017的项目属性中启用它?第二个问题:我没有找到上面的答案,所以我决定走手动路线:我创建了additional.manifest文本文件:true然后我将它添加到项目属性中:但是当我编译它时,它给了我这个警告,并且该list在应用程序运行时似乎没有任何效果:1>additional.

c++ - 初始化列表中的 QString 导致访问冲突。这里出了什么问题?

在我不理解的初始化列表中使用QString时,我遇到了访问冲突。这是一个重现问题的最小示例。//fileClassA.h#pragmaonce#includestructParameter{QStringstringPar;};classClassA{QStringm_string1;public:voidfunction(Parameterpars);};A类的实现...//fileClassA.cpp#include"ClassA.h"voidClassA::function(Parameterpars){m_string1=pars.stringPar;//lastlinecal

c++ - 在 C++14 中将 constexpr intializer_list 作为参数传递

为什么这行不通:constexprinitializer_listilist={1,2,3,4};constexprintmy_min=min(ilist);虽然这样做:constexprintmy_min=min({1,2,3,4});我的代码基于constexprstd::min()函数,如图所示here我正在使用clang3.5.0编译器(g++4.9.1似乎不知道constexprstd::min())。我无法理解我遇到的错误:clang35-stdlib=libc++-std=c++14test.cpp-otest;test.cpp:158:35:error:constexp

c++ - 运算符的初始化列表和 RHS

我不明白为什么不能在运算符的RHS上使用初始化列表。考虑:classfoo{};structbar{templatebar(Tconst&...){}};foo&operator最新的Clang(还有gcc)提示:clang.cc:14:9:error:initializerlistcannotbeusedontherighthandsideofoperator'为什么C++标准会禁止这样做?或者换句话说,为什么这会失败,而不是baz? 最佳答案 事实上,C++11的最终版本不允许在二元运算符的右侧(或左侧)使用初始化列表。首先,初