草庐IT

LDAP_bind

全部标签

c++ - 将 std::bind 与 boost::signals2 一起使用是否安全?

使用std::bind将成员函数传递给boost::signals2::signal::connect()是否安全?换句话说,boost::bind和std::bind可以互换吗?它使用VC++2010SP1编译,但模板代码让我难以理解,恐怕我可能会冒险进入未定义的行为领域。 最佳答案 我在这方面没有经验,因为我希望connect接受任何实现有效函数调用运算符的东西。使用与签名匹配的任何函数或函数对象调用它应该是安全的,无论是boost::bind、std::bind还是其他任何东西。Boost库被设计为通用的,因此它们通常不会互相

java - 运行时动态绑定(bind)和类继承的区别

我试图阐明动态语言(Python、ruby)和静态类型语言(java、C++)中运行时动态绑定(bind)和类继承的概念。我不确定我是否正确。在像Python和Ruby这样的动态语言中,运行时动态绑定(bind)是通过ducktyping实现的。当解释器检查对象的类型时,它检查对象是否具有特定的方法(或行为),而不是检查对象的类型;运行时动态绑定(bind)并不意味着类继承。类继承只是减少了Python和Ruby中的代码复制。在Java、C++等静态类型语言中,运行时动态绑定(bind)只能通过类继承获得。类继承不仅减少了这里的代码拷贝,还用于实现运行时动态绑定(bind)。综上所述,

c++ - 复制省略和临时绑定(bind)引用对象

C++草案指出:12.8p31Thiselisionofcopy/moveoperations,calledcopyelision,ispermittedinthefollowingcircumstances(whichmaybecombinedtoeliminatemultiplecopies):(...)whenatemporaryclassobjectthathasnotbeenboundtoareference(12.2)wouldbecopied/movedtoaclassobjectwiththesamecv-unqualifiedtype,thecopy/moveoper

c++ - 在 C++ 中自动绑定(bind) boost::thread?

做的时候:std::vectorvec;intnumber=4;boost::threadworkerThread(&Method,number,vec)givenamethod:templatevoidMethod(intn,std::vector&vec){//doesstuff}为什么我必须手动做:boost::threadworkerThread(&Method,number,boost::ref(vec))?为什么它不通过引用自动传递它?Edit::理论上boost::thread是否有可能做一些宏元编程来调整它,因为C++没有内置反射/内省(introspection)的方

C++ QT OSX Qt::META+Qt::Key_Tab 快捷键绑定(bind)

我正在尝试在QTabWidget中绑定(bind)Qt::META+Qt::Key_Tab快捷方式来切换标签(就像它在Chrome或许多其他应用程序)。我已经尝试了在谷歌中找到的每一个解决方案,但这个快捷方式组合不起作用。我试过:Qt::Key_Control+Qt::Key_Tab、Qt::Key_Meta+Qt::Key_Tab组合code>,QKeySequence(Qt::Key_Meta,Qt::Key_Tab),QKeySequence(Qt::META,Qt::Key_Tab)等QShortcutQAction使用虚拟QWidget::event捕获键使用虚拟QWidge

c++ - Phoenix::bind for C++11 lambdas in boost::spirit::qi 语义 Action

我的目标是创建一个解决方法,以便我可以在BoostSpiritQi语义操作中使用C++11lambda,同时仍然可以访问更多扩展的qi占位符集,例如qi::_pass或qi::_r1,而无需从上下文对象中手动提取它们。我希望避免为一些重要的解析逻辑编写Phoenixlambda,而更喜欢C++11lambda中可用的更直接的C++语法和语义。下面的代码代表了我对解决方法的想法。我的想法是使用phoenix::bind绑定(bind)到lambda并将我需要的特定占位符传递给它。但是,我遇到了一个非常长的模板化编译器错误(gcc4.7.0,Boost1.54),我没有解释的专业知识。我选

c++ - 当 vector<char>&& 绑定(bind)到 vector<char>& 时编译器不会报错

我使用的是VisualStudio2013Express。classB{public:vector&a;int&b;B(vector&i,int&c):a(i),b(c){}};intmain(){intl=3;vectorh;shared_ptrbb(newB(std::move(h),l));return0;}为什么代码可以被接受?当我将参数l更改为std::move(l)时,编译器会报错“无法将参数2从'int'转换为'int&'”。 最佳答案 这是VisualC++编译器中可用的语言扩展,现在已经存在了很长一段时间。该扩展允

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