草庐IT

member-functions

全部标签

c++ - xcode 7 如何抑制警告 "overrides a member function but is not marked ' override'”

我今天将xcode更新为7。更新后,我正在处理的项目出现警告“覆盖成员函数但未标记为‘覆盖’”。由于我们的项目将“踩踏警告为错误”设置为true。我遇到了很多错误。我仔细检查了“OtherLinkerFlags”并且非常确定“-Wsuggest-override”标志不包括在内。因为这是一个大项目,我更喜欢抑制警告,而不是在任何地方添加关键字“override”。关于禁用警告的任何建议?谢谢 最佳答案 您需要关闭-Winconsistent-missing-override标志,该标志会在最新版本的clang上自动添加-Wall。您

c++ - 错误 : no matching function for call to 'begin(int*&)' c++

#include#includeusingnamespacestd;voidprint(intia[]){int*p=begin(ia);while(p!=end(ia))coutP指向ia中第一个元素的指针。为什么它说“错误:没有匹配函数来调用'begin(int*&)'c++”谢谢!:) 最佳答案 因为在print()内部,变量ia是一个指针,而不是数组。在指针上调用begin()没有意义。 关于c++-错误:nomatchingfunctionforcallto'begin(int

c++ - 将 NULL 指针强制转换为对象并调用其成员函数之一是否有实际好处?

好的,所以我知道从技术上讲这是未定义的行为,但尽管如此,我在生产代码中不止一次看到过这种情况。如果我错了,请纠正我,但我也听说有些人使用这个“功能”作为当前C++标准缺失方面的合法替代品,即无法获取地址(好吧,真正偏移)的成员函数。例如,这是PCRE(Perl兼容正则表达式)库的流行实现:#ifndefoffsetof#defineoffsetof(p_type,field)((size_t)&(((p_type*)0)->field))#endif有人可以争论在这种情况下利用这种语言的微妙之处是否有效,甚至是否有必要,但我也看到它是这样使用的:structResult{voidsta

c++ - 我们什么时候需要 .template 结构

我做了如下程序#include#includetemplatestructClass{templatevoiddisplay(){std::coutvoidfunc(Classk){k.display();}intmain(){Classd;func(d);}上面的程序没有编译因为display()是一个模板成员函数,所以.template的资格之前display()必须完成。我说得对吗?但是当我制作下面的程序时#include#includetemplateclassmyClass{Tdummy;/*******/public:templatevoidfunc(myClassobj)

c++ - 为什么 std::tr1::function 与 Objective-C block 一起工作?

当我发现下面的代码确实有效时,我感到非常惊讶:std::vectorlist/*=...*/;std::tr1::functionfunc=^(inti){returni+1;};std::for_each(list.begin(),list.end(),func);似乎std::tr1::function能够从Objective-Cblock构造,但我不太确定是如何实现的,因为(上次我检查过),它的实现没有'专门处理block。它是否以某种方式隐式吸出底层函数指针?另外,这种行为是否未定义并且可能会改变? 最佳答案 更新:我错了,

c++ - std::function 在 VS2012 中无法编译

我正在尝试编译以下取自here的代码但我收到编译错误。有没有人知道可能出了什么问题?代码#include#includestructFoo{Foo(intnum):num_(num){}voidprint_add(inti)const{std::coutf_add_display=&Foo::print_add;Foofoo(314159);f_add_display(foo,1);}编译错误:Error1errorC2664:'std::_Func_class::_Set':cannotconvertparameter1from'_Myimpl*'to'std::_Func_base

c++ - 使用 std::function 时如何解决此 <unresolved overloaded function type> 错误?

在以下(有效的)代码示例中,模板化的register_enum()函数用于迭代枚举并调用用户提供的回调以将枚举值转换为C字符串。所有枚举都在一个类中定义,枚举到字符串的转换是使用静态to_cstring(enum)函数完成的。当一个类(如下面的着色器类)有多个枚举和相应的重载to_cstring(enum)函数时,编译器无法决定将哪个是正确的to_cstring()函数传递给register_enum()。我认为代码比我能解释得更好...#include#include//ActualcodeusesLua,butforsimplification//I'llhideitinthise

C++ 将 std::function 对象传递给可变参数模板

我想将一个可调用对象(std::function对象)传递给一个类Foo.可调用对象引用另一个具有任意参数的类的成员方法,因此Foo必须是可变参数模板。考虑这段代码:structBar{voidMemberFunction(intx){}};templateclassFoo{public:Foo(std::functionf){}};intmain(){Foom1(&Bar::MemberFunction);return0;}这编译得很好。现在我想写一个工厂函数MakeFoo()返回unique_ptr到Foo对象:templatestd::unique_ptr>MakeFoo(std

c++ - 是什么让 union 成员(member)活跃起来?

是什么让union成员活跃起来?我已经阅读了C++14标准的第9.5章(关于union的那一章),但是对于什么使union成员活跃,我还没有找到明确的答案。有一个注释:Ingeneral,onemustuseexplicitdestructorcallsandplacementnewoperatorstochangetheactivememberofaunion.例如,unionU{inti;shorts;}u;new(&u.i)int(42);好的,placementnew改变了activemember,很清楚了。但是在处理具有普通构造函数的类型时,我们通常不使用placementn

c++ - G++、clang++ 和 std::function

我只是在玩弄来自C++11的新std::function,我写了一个使用clang++3.2和英特尔C++编译器13.1编译但不使用g++4.8编译的示例。在我将其报告为错误之前,我想我应该检查一下我没有做一些非常愚蠢的事情,并且这实际上应该可以编译。那么,以下代码是否适用于c++11?templatevoidmap(C&c,std::functionf){for(auto&x:c){x=f(x);}}intmain(){std::vectorv;v.push_back(1);v.push_back(2);v.push_back(3);map(v,[](intx){returnx+2;