草庐IT

auto-close

全部标签

C++1y/14 : auto variable templates?

下面的C++1y/C++14程序格式错误吗?templateconstexprautoX=42;intmain(){static_assert(X==42,"");}为什么/为什么不?Clangtrunk提示说:error:invalidoperandstobinaryexpression('auto'and'int') 最佳答案 这是clang中的一个错误,现在已修复:http://llvm.org/bugs/show_bug.cgi?id=19152 关于C++1y/14:autov

c++ - Visual C++ 2015 在使用 decltype(auto) 时给出 C4552 警告

我想我在VisualC++2015中遇到了一个错误,但我想确定一下。考虑这个片段:templatedecltype(auto)f(Tparam){returnparam+1;}intmain(){autoi=f(10);return0;}VisualC++2015在return语句中给出了这个警告:warningC4552:'+':operatorhasnoeffect;expectedoperatorwithside-effect尽管它似乎对生成的代码没有任何影响。这是编译器错误吗? 最佳答案 这似乎是一个错误。它在这里有一个开放

c++ - 如果使用返回引用的函数初始化 'auto' var,为什么它不声明引用类型?

当使用返回引用的函数初始化“auto”变量时,为什么var类型不是引用?例如在下面的例子中,为什么x的类型是Foo而不是Foo&?classTestClass{public:Foo&GetFoo(){returnmFoo;}private:FoomFoo;};intmain(){TestClasstestClass;autox=testClass.GetFoo();//Whytypeofxis'Foo'andnot'Foo&'?return0;}编辑:该链接解释了如何获取引用,但我的问题是这种行为的原因。 最佳答案 因为那样做会很烦

c++ - 为什么必须包含 <initializer_list> 才能使用 auto?

已经有类似的question关于SO,但我想强调braced-init-lists的另一个方面。请考虑以下事项:autox={1};//(1)除非标题,否则这是错误格式(8.5.4/2)已经包括了。但为什么?标准说,模板std::initializer_list不是预定义的。这是否意味着声明(1)引入了一种新类型?在所有其他情况下,auto可以使用如autoy=expr;哪里expr是一个表达式,自动推导的类型已经存在。另一方面,从逻辑的角度来看,编译器必须为结构{1}分配一个隐式类型。,为此std::initializer_list是另一个名字。但是在声明(1)中我们不想命名这个类型

C++11 auto、std::function 和对重载函数的模糊调用

我想知道是否有人知道为什么以下示例无法编译并给出对重载函数错误的模糊调用。如果我用强类型仿函数签名替换auto,它就能够正确区分两个方法重载。我注意到当不使用std::function作为我的重载参数时,不会发生同样的问题。如果我的重载只接受一个简单的float和int,即使使用auto关键字定义我的输入参数,编译器也可以正确区分这两个重载。我正在VisualStudio2012中编译它。这可能只是VS编译器中的错误吗?我现在无法访问装有GCC或Clang的机器,但有人知道这是否可以在那里编译吗?编译错误:对重载函数的调用不明确classAmbiguousOverload{public

c++ - 初始化 auto-inc 类型 vector 的 vector 时出现问题

我正在尝试生成一个包含递增数字的单元格的二次网格。#include#includeclassSimple{public:Simple():id(genId()){}staticintgenId(){staticintg_id=0;return++g_id;}intid;};typedefstd::vector>SimpleGrid;voidprintSimpleGrid(SimpleGrid&grid){for(inti=0;irow(dim);test[i]=row;}printSimpleGrid(test);return0;}我得到这个输出:111222333这与我的预期不同:1

c++ - auto a = A(3) 和 A a(3) 有什么区别?

假设我有:structA{A(intx):m_x(x){}A(A&&)=delete;intm_x;}和:Aa(3);//Okautoa=A(3);//Error:functionA(int&&)cannotbereferenced-it'sadeletedfunction为什么后者会调用移动构造函数?为什么这2个语句在生成的代码方面不同? 最佳答案 autoa=A(3);与Aa=A(3);相同,因为右侧的类型是A。这意味着它的样子:A(3)创建一个临时的A,用3初始化,然后是Aa=_____表示:创建一个名为a的A并使用_____

c++ - auto 作为函数参数

在C++14中,这样的事情是合法的(对于lambdas):-autol=[](autox,autoy){returnx+y;};但是这样的事情仍然是不合法的:-autosum(autox,autoy){returnx+y;}我的好奇心是为什么没有将第二个添加到标准中(尽管它应该有望添加到C++17中)?第二个的优点和缺点是什么? 最佳答案 它没有被添加,因为添加是另一回事,而且时间不是无限的。我们不能指望一次性添加所有有用的增强功能,对吗?正如您所确定的,它将在C++17中。 关于c++

c++ - 围绕 avcodec_open/close 的线程锁定

我有一个c++-cli代码,它使用capture从opencv中的文件夹捕获视频,然后使用cvqueryframe检索帧。然后我处理帧,一旦处理完所有帧,我就释放捕获。它工作正常但是当我尝试多线程时它给了我一个警告并且无法捕获文件夹中的一些视频并警告“avcodec_open/close()周围的线程锁定不足”。//foreachvideoinfolderdo{capture=cvCreateFileCapture(filename);while(1){img=cvqueryframe(capture)if!imgbreak;///processimg}cvreleasecapture

c++ - "cout<<(char*)NULL"在这里做 "close(1)"吗?

这个问题在这里已经有了答案:Whydoesstd::coutoutputdisappearcompletelyafterNULLissenttoit(3个答案)关闭8年前。在下面的代码中我使用了cout在这一行之后,我的程序没有在输出屏幕上打印任何内容。这是否意味着我已经完成了close(1)与cout这里?这里到底发生了什么?这是一个错误吗?请分享您的想法。#includeusingnamespacestd;voidf(){cout我在gcc和DevCpp编译器上都试过了,观察到相同的行为。