草庐IT

auto-global

全部标签

c++ - 使用 C++ 尾随返回类型时 auto 是什么意思?

不同于平常voidfoo(void){coutC++11允许是另一种选择,使用尾随返回autobar(void)->void{cout在后者中-auto旨在表示什么?另一个例子,考虑函数autofunc(inti)->int(*)[10]{}同样的问题,这个例子中auto是什么意思? 最佳答案 一般来说,C++11中的新关键字auto表示应该从表达式的结果中推断出表达式的类型(在这种情况下是函数的返回类型),在这种情况下,->之后会发生什么。没有它,函数将没有类型(因此不是函数),编译器最终会感到困惑。

c++ - 使用 C++ 尾随返回类型时 auto 是什么意思?

不同于平常voidfoo(void){coutC++11允许是另一种选择,使用尾随返回autobar(void)->void{cout在后者中-auto旨在表示什么?另一个例子,考虑函数autofunc(inti)->int(*)[10]{}同样的问题,这个例子中auto是什么意思? 最佳答案 一般来说,C++11中的新关键字auto表示应该从表达式的结果中推断出表达式的类型(在这种情况下是函数的返回类型),在这种情况下,->之后会发生什么。没有它,函数将没有类型(因此不是函数),编译器最终会感到困惑。

c++ - 为什么 "auto const&"不是只读的?

这个问题在这里已经有了答案:Variablesmarkedasconstusingstructuredbindingsarenotconst(1个回答)关闭4年前.#includeintmain(){intxa=1;intya=2;autoconst&[xb,yb]=std::tuple(xa,ya);xb=9;//Shouldn'tthisberead-only?returnxa+ya;}这不仅编译,而且返回11。那么两个问题:为什么当xb被指定为autoconst&时我可以写入?这不应该编译失败吗?为什么我不能用“auto&”替换“autoconst&”并让它编译?Clang(6.

c++ - 为什么 "auto const&"不是只读的?

这个问题在这里已经有了答案:Variablesmarkedasconstusingstructuredbindingsarenotconst(1个回答)关闭4年前.#includeintmain(){intxa=1;intya=2;autoconst&[xb,yb]=std::tuple(xa,ya);xb=9;//Shouldn'tthisberead-only?returnxa+ya;}这不仅编译,而且返回11。那么两个问题:为什么当xb被指定为autoconst&时我可以写入?这不应该编译失败吗?为什么我不能用“auto&”替换“autoconst&”并让它编译?Clang(6.

c++ - 为什么 decltype 在这里工作,但不是 auto?

我的代码如下:templatevoidprint2d(constT&data,sepTsep=','){for(autoi=std::begin(data);i>v={{11},{2,3},{33,44,55}};print2d(v);intarr[2][2]={{1,2},{3,4}};print2d(arr);return0;}如果我将decltype更改为auto,它不会编译并报错(部分错误):2d_iterator.cpp:Ininstantiationof‘voidprint2d(constT&,sepT)[withT=int[2][2];sepT=char]’:2d_ite

c++ - 为什么 decltype 在这里工作,但不是 auto?

我的代码如下:templatevoidprint2d(constT&data,sepTsep=','){for(autoi=std::begin(data);i>v={{11},{2,3},{33,44,55}};print2d(v);intarr[2][2]={{1,2},{3,4}};print2d(arr);return0;}如果我将decltype更改为auto,它不会编译并报错(部分错误):2d_iterator.cpp:Ininstantiationof‘voidprint2d(constT&,sepT)[withT=int[2][2];sepT=char]’:2d_ite

c++ - 在不执行程序的情况下在 C++11 中检索 auto 的类型

我有一些使用auto推断类型的C++11代码,我必须将其转换为C++98。我将如何转换代码,用实际类型替换auto的所有实例? 最佳答案 它将是一个PITA,但您可以声明一个不完整的结构模板,接受单个类型参数。给定变量x您想知道其类型,您可以将结构与decltype(x)一起使用,这将导致编译器错误,该错误将显示你是推断的类型。例如:templatestructS;intmain(){autox=...;S();}Livedemo这将产生如下形式的错误消息:error:implicitinstantiationofundefined

c++ - 在不执行程序的情况下在 C++11 中检索 auto 的类型

我有一些使用auto推断类型的C++11代码,我必须将其转换为C++98。我将如何转换代码,用实际类型替换auto的所有实例? 最佳答案 它将是一个PITA,但您可以声明一个不完整的结构模板,接受单个类型参数。给定变量x您想知道其类型,您可以将结构与decltype(x)一起使用,这将导致编译器错误,该错误将显示你是推断的类型。例如:templatestructS;intmain(){autox=...;S();}Livedemo这将产生如下形式的错误消息:error:implicitinstantiationofundefined

c++ - 错误 C2039 : 'memchr' : is not a member of '` global namespace''

自从我在标准头文件中无缘无故地收到此错误以来已经有一段时间了。谷歌搜索带来了许多答案,但没有一个有效。 最佳答案 好的,我自己修好了。这是一个愚蠢的错误!我在一个库项目中有一个名为“String.h”的文件,该文件被header拾取。可能是因为我已将的路径添加为我的测试项目中的附加包含目录(我收到此错误。)希望这对某人有所帮助。 关于c++-错误C2039:'memchr':isnotamemberof'`globalnamespace'',我们在StackOverflow上找到一个类似

c++ - 错误 C2039 : 'memchr' : is not a member of '` global namespace''

自从我在标准头文件中无缘无故地收到此错误以来已经有一段时间了。谷歌搜索带来了许多答案,但没有一个有效。 最佳答案 好的,我自己修好了。这是一个愚蠢的错误!我在一个库项目中有一个名为“String.h”的文件,该文件被header拾取。可能是因为我已将的路径添加为我的测试项目中的附加包含目录(我收到此错误。)希望这对某人有所帮助。 关于c++-错误C2039:'memchr':isnotamemberof'`globalnamespace'',我们在StackOverflow上找到一个类似