草庐IT

LD_BIND_NOW

全部标签

c++ - 您自己的类型的结构化绑定(bind)不是结构或元组(通过公共(public)成员函数)

我正在浏览HerbSutter的旅程:走向更强大、更简单的C++编程StructureBinding节为了理解这个概念。最好是写一个我试过但出现一些错误的程序Justwanttotryhowtousestructurebindingonclasswithprivatedata.Pleaseignorethebelowexample.ifanyexampleyoucanprovide#include#includeusingnamespacestd;classfoobar{public:foobar(){coutstructtuple_element{usingtype=int;};te

c++ - 为什么这个引用绑定(bind)格式错误?

考虑这段代码:int**p=0;classS{public:explicitoperatorint**&(){returnp;}};intmain(){Sa;int*const*&b(a);//errorinbothg++-7andclang-5.0with"-std=c++17"return0;}你会同意从int**到int*const*的限定转换是可能的,并且int*const*&b(a)是一个直接初始化。首先,我们引用n4700中的11.6.3第5段[dcl.init.ref].Areferencetotype“cv1T1(=int*const*)”isinitializedby

c++ - 将函数直接传递给 std::async 和使用 std::bind 有什么区别?

我最近开始向我正在处理的库添加异步支持,但我遇到了一个小问题。我从这样的事情开始(稍后会有完整的上下文):returnexecuteRequest(false,d,&callback,false);那是在添加异步支持之前。我试图将其更改为:returnstd::async(std::launch::async,&X::executeRequest,this,false,d,&callback,false);但是编译失败。MCVE:#include#includeintcallback(constint&t){std::coutTexecuteRequest(boolmethod,Req

C++ SQL绑定(bind)参数

这里是变量的声明:stringstrFirstName;stringstrLastName;stringstrAddress;stringstrCity;stringstrState;doubledblSalary;stringstrGender;intintAge;...做一些“cin”语句来获取数据...retcode=SQLPrepare(StatementHandle,(SQLCHAR*)"INSERTINTOEMPLOYEE([FirstName],[LastName],[Address],[City],[State],[Salary],[Gender],[Age])VALU

c++ - 如何为 boost::bind 强制模板函数重载?

我正在尝试通过使用boost::bind和boost::contains为std::find_if创建谓词(来自提升/算法/字符串库)。以下代码段显示了我如何尝试实现此目的的两种方式。#include#include#include#include#includeintmain(intargc,char**argv){std::strings1("hellomom");std::strings2("byemom");boost::functionf=&boost::contains;std::coutcontain_hello=boost::bind(boost::contains,_

c++ - Ld 神奇地覆盖静态链接的符号

这几天我们一直在处理非常奇怪的问题。我什至无法理解它是如何发生的——当第三方(MATLAB)程序使用我们的共享库时,它会以某种方式用它自己的符号覆盖我们的一些符号(准确地说是增强)。这些符号是静态链接的并且(!!)是本地的。这是交易-我们使用boost1.47,MATLAB有boost1.40。目前,库在从我们的库调用它们的boost(正则表达式)时会出现段错误。所以,这是神奇的:我们没有依赖库,ldd:linux-vdso.so.1=>(0x00007fff4abff000)libpthread.so.0=>/lib/libpthread.so.0(0x00007f1a3fd6500

c++ - 如何在 C++ 绑定(bind)中使用不透明指针包装 C 库

我正在考虑用C++包装一些C库,但我不确定包装不透明指针的最佳方法是什么。当C语言结构是公共(public)API的一部分时typedefstruct_SomeType{inta;intb;}SomeType_t;有几个“成员”函数的地方:voidSomeTypeFoo(SomeType_t*obj,...);voidSomeTypeBar(SomeType_t*obj,...);我喜欢从基派生的方法,将这些“成员”函数简单地关联为实际的类成员。即:classSomeTypeWrapper:publicSomeType_t{voidfoo(...);voidbar(...);};就我的

C++ std::bind 重新绑定(bind)函数

如果我像这样绑定(bind)一个函数,在绑定(bind)时使用占位符std::bind(memberFunctionPointer,objectPointer,_1,_2);然后是否可以稍后“重新绑定(bind)”它以替换一些/所有占位符,但不调用该函数?我希望能够传入一些参数然后存储它,以便稍后调用。(延迟回调) 最佳答案 您可以再次绑定(bind):autof=std::bind(memberFunctionPointer,objectPointer,_1,_2);autog=std::bind(f,val1,val2);g()

c++ - 在 C++ 中绑定(bind)多个引用的临时对象的生命周期

C++标准草案N4296说[class.temporary/5]Thesecondcontextiswhenareferenceisboundtoatemporary.Thetemporarytowhichthereferenceisboundorthetemporarythatisthecompleteobjectofasubobjecttowhichthereferenceisboundpersistsforthelifetimeofthereferenceexcept...所以我想知道如果两个或多个引用绑定(bind)到一个临时文件会发生什么。它在标准中有具体规定吗?以下代码可能

c++ - 无法从 std::bind 推断出 std::function 的模板参数

我正在尝试找到一种方法来调用多个类成员函数,每个函数都有不同的参数,并且在调用前后会发生某些已知功能。这个包装函数是我试过的,但是例如对它的最终调用不会编译错误:'boolWrapper(Work*,std::function,Args&&...)':couldnotdeducetemplateargumentfor'std::function'from'std::_Bind,Work*const>'classWork{public:voidDoWork(inta,doubleb,stringc);private:voidPre(){};voidPost(){};boolStep1()