大佬教程收集整理的这篇文章主要介绍了没有clang警告或错误,如果C 11 lambda返回错误类型,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
#include <functional> typedef std::function<void()> voidFunc; void foo(voidFunc funC) { func(); } int main() { int i = 42; foo([i]() { return i; }); return 0; }
clang++ -c -Xclang -stdlib=libc++ -std=c++11 -Weverything -Wno-c++98-compat -Wno-missing-prototypes -o foo.o foo.cpp
编辑:
#include <functional> struct A {}; struct B {}; typedef std::function<A()> aFunc; void foo(aFunc funC) { func(); } int main() { int i = 42; foo([i]() { return B(); }); return 0; }
这是错误:
foo2.cpp:16:2: error: no matching function for call to 'foo' foo([i]() { ^~~ foo2.cpp:8:6: note: candidate function not viable: no kNown conversion from '<lambda at foo2.cpp:16:6>' to 'aFunc' (aka 'function<A ()>') for 1st argument void foo(aFunc funC) ^ 1 error generated.
可以像调用void()函数一样调用示例中的lambda;忽略返回值从来都不是C中的类型错误(这是一个好的或坏的想法是一个不同的问题).
因此,std :: function< void()>允许这样的对象.显示的第一个程序完全有效.
但是,第二个程序中的lambda不能在A()函数的任何地方调用:
void f(A const&); f(the_lambda()); // nope!
所以第二个程序无效,编译器正确报告.
如果您想在这种情况下出现类型错误,则需要进行自己的类型检查.在这种情况下,你可以简单地static_assert,std :: result_of< T()> :: type与void相同.但是,一般情况下,这是不可能的,因为在C中,所有可调用的对象(除了像void()这样的退化对象都有多个可能的调用签名,这要归功于隐式转换等功能.
†我可能要在这里通过“呼叫签名”来解释我的意思.我指的是实际调用中使用的类型,或者可能是返回值的调用赋值,而不是声明的签名中明确存在的类型.请考虑以下代码.
long f(doublE); double d; int i; long a = f(d); // call signature is long(doublE) // called with double,returning into a long short b = f(i); // call signature is short(int) // called with int,returning into a short
以上是大佬教程为你收集整理的没有clang警告或错误,如果C 11 lambda返回错误类型全部内容,希望文章能够帮你解决没有clang警告或错误,如果C 11 lambda返回错误类型所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。