草庐IT

FUNCTION_NAME

全部标签

c++ - 什么时候用 "class_name obj_name = func()"替换 "class_name obj_name{func()}"有意义?

在代码中我看到了以下结构:constclass_nameobj_name{func()};func()返回名为class_name的类的对象。所以,我想知道为什么不使用以下结构:constclass_nameobj_name=func(); 最佳答案 constclass_nameobj_name{func()};作者通过写上面的代码,试图遵循统一初始化语法(C++11引入),从而避免繁琐的解析和最令人烦恼的解析,即使是经验丰富的程序员也会意外陷入其中。他正试图将最佳实践灌输到他的大脑中,这样他就不会偶尔陷入上述解析问题,如下所述。

c++ - 为什么 std::function<boost::any ()> 在这种情况下不起作用?

我遇到过需要这种功能的情况:MoveOnlycreateMoveOnly();存储在这里:std::functionfactory=&createMoveOnly;据我所知,这应该可行,因为MoveOnly可以转换为boost::any使用支持boost.any移动语义的boost1.55,它不起作用。它会触发有关尝试在boost::any的持有者内部为MoveOnly使用已删除的复制构造函数的错误。但是正确选择了Boost.Any的顶级构造函数(它使用模板化的ValueType&&来转发参数)。也许问题出在std::function中。有什么提示吗? 最佳

该名称[&lt; name&gt;]的Hibernate参数不存在

我正在运行以下代码。uservice.javaStringalias="u";Stringselect="SELECTu.email";Stringwhere="u.userId=:id";Mapparams=newHashMap();params.put("id",userId);Listusers=db.findRecords(User.class,alias,select,where,params);DB.JavapublicListfindRecords(ClassentityClass,StringentityAlias,Stringselect,Stringwhere,Mappar

c++ - std::vector of function pointers:不同的模板参数

为什么下面会编译std::vectorfunc_ptrs;但这不是std::vectorfunc_ptrs?在第二种情况下,我收到了那些丑陋的STL错误消息之一,所以我不打算将所有内容都放在这里,但在消息的末尾我得到了这个/usr/include/c++/4.8/bits/stl_construct.h:102:30:error:ISOC++forbidsincrementingapointeroftype‘int(*)(double)’[-fpermissive]for(;__first!=__last;++__first)这似乎暗示C++将类型int(double)转换为int(*

c++ - 一个 const std::function 包装一个非常量 operator()/mutable lambda

考虑以下示例:#include#includestructA{inti;voidoperator()(){std::coutconst&fun){fun();}intmain(){conststd::functionf{A{}};test(f);test(f);}在这里,conststd::function能够调用非constoperator().输出:12如果我提供一个mutablelambda,也会发生同样的情况,例如test([x=0]()mutable{++x;});这怎么可能?conststd::function可以包装可变仿函数是否正常? 最佳答

c++ - 视觉 C++ 错误 : function must return a value

我正在做一个多平台项目,有些平台禁用了功能,在这些功能的界面中,我经常做的事情是这样的:boolFoo::bar()const{//disabledabort();}GCC/LLVM不要求非void函数返回值(它们只是给出警告),在这种情况下,我调用abort()时,它们足够聪明,甚至不会发出警告(因为该函数永远不会返回)。有没有办法(编译标志?)让VisualC++2010以相同的方式运行,这样我就不会继续破坏Windows构建?我知道我总是可以在中止后返回值,但在其他平台上工作时我通常会忘记这一点,不给出错误的行为似乎更合适。 最佳答案

c++ - 计时代码 "C2440: ' <function-style-cast >' : cannot convert from ' _CR' to 'std::chrono::milliseconds' 中的一个奇怪错误

我偶然发现了一个奇怪的错误C2440:'':cannotconvertfrom'_CR'to'std::chrono::milliseconds'基本上相当于HowardHinnant'sanotherquestion中的代码.这应该在VisualStudio2012RC上编译吗?这个问题的原因是什么?修复或解决方法如何?我的目标只是创建一个简单的计时器(没什么太严肃的),所以如果存在这种效果,将采取点-以及其他实现线索。问题代码如下。用法:timers::stopwatchw;w.start();std::cout并且头文件是(为简洁起见省略了实现)namespacetimers{c

C++ 等效于 Tensorflow 中的 python : tf. Graph.get_tensor_by_name()?

Python的C++等价物是什么:Tensorflow中的tf.Graph.get_tensor_by_name(name)?谢谢!这是我尝试运行的代码,但我得到一个空的输出:Statusstatus=NewSession(SessionOptions(),&session);//createnewsessionReadBinaryProto(tensorflow::Env::Default(),model,&graph_def);//readGraphsession->Create(graph_def);//addGraphtoTensorflowsessionstd::vector

C++ 函数回调 : Cannot convert from a member function to a function signature

我正在使用第3方库,它允许我为某些事件注册回调。注册函数看起来像这样。它使用回调签名。typedefint(*Callback)(std::string);voidregisterCallback(CallbackpCallback){//itgetsregistered}我的问题是我想像这样注册一个成员函数作为回调structMyStruct{MyStruct();intmyCallback(std::stringstr);};MyStruct::MyStruct(){registerCallback(&MyStruct::myCallback);}intMyStruct::myCa

c++ - 确定与 std::function<R(T1,T2)> 兼容的函数类型集的规则?

假设我有这个,std::functionfs;那么我如何确定fs的函数集(或函数对象)可以初始化吗?以下哪些是允许的,哪些不是:std::functionfs=[](int,int){returnint(10);};std::functionfs=[](char,char){returnchar(10);};std::functionfs=[](int,short){returnint(10);};std::functionfs=[](double,int){returnfloat(10);};std::functionfs=[](int,wchar_t){returnwchar_t(