草庐IT

load_functions

全部标签

c++ - 如何从移动捕获 lambda 表达式创建 std::function?

我正在尝试创建一个std::function来自移动捕获lambda表达式。请注意,我可以毫无问题地创建移动捕获lambda表达式;仅当我尝试将其包装在std::function中时我得到一个错误。例如:autopi=std::make_unique(0);//noproblemshere!autofoo=[q=std::move(pi)]{*q=5;std::coutbar=foo;std::functionbar{foo};std::functionbar{std::move(foo)};std::functionbar=std::move(foo);std::functionba

c++ - boost::function 如何支持不同长度模板参数的模板类

我想使用boost预处理器来声明具有不同模板变量长度的模板类,基本上就像boost::function所做的那样。#if!BOOST_PP_IS_ITERATING#ifndefD_EXAMPLE_H#defineD_EXAMPLE_H#include#include#defineBOOST_PP_ITERATION_PARAMS_1(3,(1,2,"example.h"))#includeBOOST_PP_ITERATE()#elsetemplateclassExample{boost::functionfunc;};#endif上面的代码显然不会工作,因为它在同一个头文件中声明了具

c++ - std::function:参数的严格编译时验证

我想实现一个类,它包含两个带有预定义函数签名的回调。该类具有模板化构造函数,它使用std::bind来创建std::function成员。我预计编译器(g++4.6)会提示如果将签名错误的函数传递给ctor。但是,编译器接受以下内容:callbackc1(i,&test::func_a,&test::func_a);我能理解它为什么这样做。我试图为static_assert构造一个适当的条件,但没有成功。如何通过编译时错误来避免这种情况?#includeusingnamespacestd::placeholders;classcallback{public:typedefstd::fu

读书笔记【头先Python】4. List of Files: Functions, Modules & Files

HowtocreateafunctioninPythonLeaveyour swimclub.py codeopeninVSCode(ifyoulike),thenopenanothernewnotebook,andcallit Files.ipynb.YoualreadyknowhowPython’s import statementworkswiththePSL.Itturnsout import canalsoimportyourcustommodules.And,guesswhat?The swimclub.py fileisaPythonmodule,soyoucanuse impo

C++ 11 绑定(bind) std::function 与存储元组和解包

首先,我对C++11还是比较陌生,所以如果我遗漏了什么,请原谅我的疏忽。所以我想做的基本上是让调用者传入一个函数和该函数的任意参数,将其存储起来,然后稍后异步调用它。似乎有2个主要选项:使用std::bind将std::function绑定(bind)到它的参数(使用可变参数模板获得),然后稍后调用它将参数包转换为一个元组,存储它和std::function,然后再次将元组解压为多个参数并使用它调用函数问题是,一种方法比另一种更好吗?两者之间有优缺点/性能优势吗?谢谢!编辑:根据要求,这里有一个澄清,第一种情况是更早的绑定(bind),我将args绑定(bind)到函数,只要调用者传递

c++ - 错误 : no instance of overloaded function

我正在尝试使用以下代码在我的数据库(SQLServer2008)中插入一些行:CDB.cpp#include"CDB.h"voidCDB::ajouterAlerte(){SqlConnection^mySQLConnection;SqlDataAdapter^myDataAdapter;DataSet^myDataSet;DataRow^myRow;SqlParameter^myParameter;try{mySQLConnection=gcnewSqlConnection("DataSource=NECTARYS-PC;InitialCatalog=MonitoringN;Inte

c++ - AVX:数据对齐:store crash,storeu,load,loadu 没有

我正在修改RNNLM一个神经网络来研究语言模型。但是考虑到我的语料库的大小,它运行得非常慢。我试图优化矩阵*vector例程(这是一个占小数据集总时间63%的例程(我预计它在大数据集上会更糟))。现在我坚持使用内在函数。for(b=0;b此示例崩溃于:_mm256_store_ps(&(dest.ac[b*8+from+0]),t4);但是如果我改成_mm256_storeu_ps(&(dest.ac[b*8+from+0]),t4);(我想你是未对齐的)一切都按预期进行。我的问题是:为什么load可以工作(而如果数据未对齐,它不应该工作)而store却不能。(此外,两者都在同一个地址

c++ - 处理 QPluginLoader::load() 抛出的异常

我有2个Qt插件,main和helper,main.dll加载helper.dll。当main.dll和helper.dll都在时,我能够使用QPluginLoader成功加载main.dll同一个文件夹。当helper.dll不存在并且我尝试加载main.dll时,抛出异常。这是可以理解的原因helper.dll找不到。我的任务是成功捕获抛出的异常,而不是让应用程序崩溃。调试时QtCreator显示的是:下面的代码没有解决问题,所以我需要做点别的……std::exception_ptreptr;QPluginLoaderpluginLoader(packagePath);try{pl

c++ - std::tr1::function::target<TFuncPtr> 和协变/逆变

因为我喜欢用C#和C++编程,所以我打算实现一个类似C#的事件系统,作为我计划的C++SFML-GUI的坚实基础。这只是我的代码的摘录,我希望这能澄清我的概念://Event.h//STLheaders:#include#include#include//boostheaders:#include#includenamespaceUtils{namespaceGui{#defineIMPLEMENTS_EVENT(EVENTNAME,EVENTARGS)public:\Utils::Gui::IEvent&EVENTNAME(){returnm_on##EVENTNAME;}\prot

c++ - 嵌套的 std::function

有可能有一个std::function吗?返回std::function并使用与其他std::functions递归的各种函数,比如函数的函数?换句话说,我想将一组函数折叠成一个函数。例如脱离基础教程doublegenFunc(doublex,std::functionf){doubleres=f(x);returnres;}doublesquare(doublex){returnx*x;}doubledbl_sq(doublex){returnsquare(x*x);}我如何修改它以允许嵌套std::function电话? 最佳答案