草庐IT

bind_param

全部标签

c++ - 绑定(bind)到私有(private)继承的成员函数

我想将std::bind到私有(private)基类的成员函数,在派生类中使用using声明使其“公开”。直接调用函数是可行的,但绑定(bind)或使用成员函数指针似乎无法编译:#includestructBase{voidfoo(){}};structDerived:privateBase{usingBase::foo;};intmain(int,char**){Derivedd;//callmemberfunctiondirectly://compilesfined.foo();//callfunctionobjectboundtomemberfunction://nomatchi

c++ - XML/C++ 类型绑定(bind)出错

我有一个WSDL文件,我需要从中生成一个C++Web服务代码。我使用的工具链是gSOAP。问题是生成的服务器类,每个操作都有一个函数,参数为char*而不是像ns2__something结构。我如何强制gSOAP生成XML/C或XML/C++绑定(bind)(根据我对gSOAPdocumentation的理解,它应该这样做[?])WSDL文件:gSOAP参数:wsdl2h-c++11-g-a-w-y-oSWUS.h../docs/service.wsdlsoapcpp2-2-S-a-A-t-c++11-b-i./SWUS.h生成的代码片段:classSOAP_CMACswusServi

c++ - 如何有效地将左值或右值绑定(bind)到同一个引用?

假设您有一个C++函数,它使用了(常量)参数的更改版本。MyObjectalter_obj(MyObjectconst&obj);//Createsnew,alteredobjectvoidfunc(MyObjectconst&original){MyObjectconst&altered(alter_obj(original));//...}由于“最重要的常量”导致临时对象的生命周期延长,因此可以正常工作。如果alter_obj()满足返回值优化的要求,它也相当有效,因为RVO意味着不会不必要地复制值返回的更改对象。如果您根本不进行更改,它也会很有效:voidfunc(MyObjec

c++ - 在 C++ 中实现 sql 语句绑定(bind)的最佳方法

好的,所以我正在用c++0x编写一个DB包装器,API在C中。我已经准备好可以在运行时绑定(bind)的语句。我想在对包装器的1个函数调用中绑定(bind)并执行语句。虽然我最初是使用变体模板。但是根据我看到的文档,我还没有找到如何将作为模板类型输入的类型限制为固定集(int、string、double),以及如何能够对这些类型执行基本逻辑。类似(伪代码)foreacharginargsifarg1==std::stringbindToString(arg);elseifint...谢谢 最佳答案 利用函数重载。voidbind(s

c++ - 有没有办法在 Qt GUI 应用程序的工作线程中使用 OpenGL 安全地绑定(bind)纹理?

我目前正在开发一个使用Qt可视化3D场景的GUI软件项目。GUI允许用户加载批量3D数据文件,例如具有一些.mtl支持的.obj和.STL以及2D图像文件作为SceneObject类对象加载到场景中,这些对象在QGLWidget派生的小部件上呈现。然而,当我在主GUI线程上批量加载它们时,较长的加载时间导致GUI卡住,这很丑陋。我曾尝试在单独的线程上执行加载,但有一个大问题:加载.obj纹理或图像文件时,我还将在加载每个图像或纹理后立即使用OpenGLglBindtexture()执行绑定(bind),这样我只需要保存每个SceneObject实例中的纹理ID。当我尝试在工作线程中执行

java - Java 中 C++ 的 std::bind 是否等效?

有没有一种方法可以像在C++中使用std::bind那样将参数参数绑定(bind)到Java中的函数指针?类似这样的Java等价物是什么?voidPrintStringInt(constchar*s,intn){std::cout>funcs;funcs.push_back(std::bind(&PrintStringInt,std::placeholders::_1,4));funcs.push_back(std::bind(&PrintStringString,std::placeholders::_1,"bar"));for(autoi=funcs.begin();i!=func

c++ - 在 C++ 11 中将非常量左值引用绑定(bind)到右值是否有效?(已修改)

我知道在c++03中,非常量引用不能绑定(bind)到右值。T&t=getT();无效,在c++11中,我们可以这样做:T&&t=getT();但是上面的代码,应该在c++11中工作吗?我用vs11测试了下面的代码:FoogetFoo(){returnFoo();}voidfz(Foo&f){}intgetInt(){returnint();}voidiz(int&i){}intmain(){{Foo&z=getFoo();//okfz(getFoo());//okint&z2=getInt();//error:initialvalueofreferencetonon-constmus

c++ - C++ 临时对象的生命周期是在什么时候创建的? : expression extended by binding it to a local const reference?

我不清楚是否可以通过将临时对象绑定(bind)到?:表达式中的常量引用来延长临时对象的生命周期:classFoo{...};Foo*someLValue=...;constFoo&=someLValue?*someLValue:Foo();通过调用默认构造函数Foo()创建的临时对象的生命周期是否通过将其绑定(bind)到本地constref来延长,即使绑定(bind)是有条件的?还是因为Foo()的临时值会在?:表达式的末尾被销毁,所以这会创建一个悬空引用? 最佳答案 在此代码中,条件运算符的第二个和第三个操作数具有不同的值类别(

c++ - 绑定(bind)函数如何在 C++ 中对函数对象起作用

我遇到了以下find_if函数。find_if(coll.begin(),coll.end(),bind(logical_and(),bind(greater(),_1,x),bind(less(),_1,y)));我怀疑bind(greater(),_1,x)和bind(less(),_1,y)是如何计算并在那里返回bool值的?否则这将不起作用,如下所示。#include#includeintmain(){usingnamespacestd::placeholders;//autofn=std::bind(std::greater(),5,_1);//std::cout(),5,6

c++ - STL 分配器,其他类型的复制构造函数,重新绑定(bind)

STL分配器需要这种构造函数形式(20.1.5):Xa(b);并要求Y(a)==b;在标准实现中,这意味着并实现为:templateallocator(constallocator&o)throw()我无法理解为何存在此要求。我知道分配器应该是静态的(没有任何状态),但到底为什么要能够像这样转换它们? 最佳答案 允许从其他分配器构造,因为容器需要使用与您指定的不同的分配器类型。例如,列表和映射分配它们的内部节点类型而不是它们公开的value_type。代码类似于:template>structContainer{typedefTva