草庐IT

function-call-operator

全部标签

c++ - 为什么在 C++11 中会多次提及 "function prototypes"?当然这些在 C++ 中不存在

C++11标准多次提及“函数原型(prototype)”。没有任何相关特征的定义,但在随机的地方,如:[C++11:3.3.4]中的“函数原型(prototype)范围”(其定义实际上承认它在谈论“函数声明”);[C++11:17.5.1.4/1]中库类型定义子句的编辑描述,脚注175(这似乎指的是C功能);[C++11:20.9.4.3/6]它描述了假设的templatetypenameadd_rvalue_reference::typecreate();作为“函数原型(prototype)”。在[C++11:20.9.6/4]同样的事情;附录[C++11:C.1.7]其中谈到了C中

c++ - Cython 不能使用 operator()

当我尝试使用以下Cython代码时,我收到了我在最后发布的有关未定义operator()的错误。看来,当我尝试使用运算符时,Cython不会将其解释为成员函数(注意C++源代码中没有成员访问权限)。如果我尝试调用prng.operator()(),那么Cython将无法转换。在Cython中使用运算符重载是否需要一些特殊的东西?importnumpyasnpcimportnumpyasnpcdefexternfrom"ratchet.hpp"namespace"ratchet::detail":cdefcppclassRatchet:Ratchet()unsignedlongget64

c++ - 如何确保 std::call_once 真的只被调用一次

我正在使用的一些代码使用std::call_once以便某些初始化只发生一次。但是,有些全局对象的构造函数最终会调用初始化代码。在下面的示例中,call_once实际上被调用了两次。我猜这是因为once_flag构造函数在使用之前没有运行。有没有办法解决这个问题,使一些初始化代码只被调用一次而不必禁止全局变量?#include#includeusingnamespacestd;voidInit();classGlobal{public:Global(){Init();}};Globalglobal;once_flagflag;voidInit(){call_once(flag,[]{c

c++ - "If you' 已经写了一个编译测试,你've written a call to main"

在程序中调用mainviolatesC++标准voidf(){main();//anendlessloopcallingmain?Nothat'snotallowed}intmain(){staticint=0;std::cout在lecture中ChandlerCarruth,大约在“22.40”说ifyou'vewrittenacompilertestyou'vewrittenacalltomain这有什么关系,或者如何克服标准不允许的事实? 最佳答案 这里的要点是,如果你编写编译器测试代码,你可能会想用一些不同的参数集测试调用

c++ - std::function 性能与模板相比

这个问题在这里已经有了答案:Speedofboundlambda(viastd::function)vsoperator()offunctorstruct(1个回答)关闭7年前。我看了另一个关于std::function的堆栈溢出问题以及为什么它很慢,但我仍然不相信/不明白。我根据问题运行程序并进行了一些修改。#include#include#include#includetemplatefloatcalc1(Ff){return-1.0f*f(3.3f)+666.0f;}floatcalc2(conststd::function&f){return-1.0f*f(3.3f)+666.

c++ - 遗传算法 : Langermann's function and Tournament selection

我在理解如何在我的遗传算法中实现Langermann函数和锦标赛选择时遇到了一些困难。我有this作为Langermann函数的引用,但我不明白C值从何而来,因为我只有X和Y。C值总是一组常数吗?至于锦标赛选择,我想随机选择我的人群中的任意3个人并比较他们的健康状况。一旦能够使用Langermann函数生成适应度值,我会将每个适应度值存储在一个vector中。然后我想从vector中选择3个独特的随机元素并将它们相互比较。如何在不使用相同数字的情况下从vector中选择3个唯一的随机元素?感谢任何帮助! 最佳答案 istheCval

c++ - 从 std::map 中删除 std::function lambda-wrapped 方法

我正在使用std::function和std::map创建一个回调系统。该映射使用int作为键,值为std::function。我将方法绑定(bind)到这些函数中。我想知道如果我调用map.erase(i),会从内存中删除std::function,还是会发生内存泄漏?下面是一些示例代码:#include#include#includeusingnamespacestd;classTestClass{public:TestClass(int_i,map>&test_map):i(_i){test_map[i]=[&](){this->lambda_test();};};voidlam

c++ - 在没有类声明的情况下使用 Qt 的 Q_DECLARE_FLAGS 和 Q_DECLARE_OPERATORS_FOR_FLAGS

我有以下枚举声明,我想利用Qt中的QFlags支持来实现额外的类型安全:namespacessp{enumVisualAttribute{AttrBrushColor=0x001,AttrBrushTexture=0x002,AttrPenCapStyle=0x004,AttrPenColor=0x008,AttrPenJoinStyle=0x010,AttrPenPattern=0x020,AttrPenScalable=0x040,AttrPenWidth=0x080,AttrSymbolColor=0x100,AttrTextColor=0x200,AttrTextFontFam

c++ - libstdc++ 和 libc++ : operator>> on bitset 行为差异

考虑以下代码:#include#include#includeintmain(intargc,char*argv[]){std::stringstreamstream;std::bitsetbitset(1);std::cout>bitset;std::cout在g++下用libstdc++编译,结果为:>g++bitset_empty.cpp-obitset_empty>./bitset_emptybefore=1after=1在clang++下用libc++编译,结果为:>clang++-stdlib=libc++bitset_empty.cpp-obitset_empty>./b

c++ - 为什么这个用于检测类型 T 是否具有 void operator(EDT const&) 的 C++ 特性会失败?

我正在尝试使用SFINAE来检测作为模板参数T传递的类型是否具有T::operator()(Pconst&),其中P也是模板参数。我在MemberDetectorIdiom的这个例子之后为我的解决方案建模不幸的是,我无法让它为operator()工作,即使我可以让它为普通方法工作。下面是一些演示我面临的问题的示例代码:#include#include#include#includeusingnamespacestd;structhas{voidoperator()(intconst&);};structhasNot1{voidoperator()(int);};structhasNot