草庐IT

some_friend_function

全部标签

c++ - "friend struct A;"和 "friend A;"语法有什么区别?

做和做有什么区别:structA;structB{friendstructA;};和structA;structB{friendA;};第二部分省略struct是什么意思? 最佳答案 不同的是,如果你写friendA;,A必须是一个已知的类型名,也就是说它必须在之前声明。如果你写friendstructA;,这本身就是A的声明,所以不需要事先声明:structB{friendstructA;};//OK虽然有一些微妙之处。例如,friendclass/structA在类B的最内层封闭命名空间中声明类A(感谢CaptainObvlio

C++ 中 <iterator> <functional> <numeric> 库好用的函数

C++中库好用的函数泰裤辣!简述:迭代器省代码用的。std::advance记忆方法:advance-前进。形如:advance(it,step),表示it迭代器自增step步。实现类似于:functionadvance(&it,n): whilen>0: --n ++it whilen或functionadvance(&it,n): it+=nstd::next&std::prev记忆方法:自己问英语老师。形如next(it,n)及prev(it,n),默认n=1,表示迭代器前移、后移n位。为std::advance的变体,区别在于返回了迭代器而传入迭代器不改变。实现类似于:functi

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++ - 一个类的方法中的本地类是这个类的 friend 吗?

我有一个外部类A。它有一个方法A::fun。在这个方法中,它有一个本地或内部类B。我的问题是:B是A的friend吗?我认为不是。这样对吗?如果是这样,我认为让B类成为A的friend是非常有益的,因为B可以访问A's私有(private)和protected成员。而且,由于B在方法中是本地的,其他人无法访问它,因此作为A的友元是安全的。如何让B访问A的私有(private)和protected成员? 最佳答案 不,他们不是friend。但是局部类对函数外部的名称具有与函数本身相同的访问权限。标准说:9.8Localclassdec

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++ 全局外部 "C" friend 无法访问命名空间类上的私有(private)成员

请考虑代码:#includeusingnamespacestd;extern"C"voidfoo(void);namespaceA{templateclassBar{private:friendvoid::foo(void);staticvoidprivate_func(intn);};templatevoidBar::private_func(intn){cout::private_func("::private_func(1);}intmain(){coutG++给出:>g++-Wall-oextern_cextern_c.cppextern_c.cpp:Infunction‘vo

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