草庐IT

通用化

全部标签

c++ - 通用等价于 std 函数对象

boost中是否有任何函数对象是std::equal_to、std::greater等函数对象家族的通用等价物?本质上,std::equal_to应该变成类似structgeneric_equal_to{templatebooloperator()(constT&t,constU&u)const{returnt==u;}};我可以看到由于返回类型的问题,std::plus等的通用版本可能会更加棘手(尽管decltype可以解决这个问题)。不过,我看不出std::equal_to函数对象本身需要模板参数的任何可能原因。这些版本肯定存在于boost或STL中的某个地方吗?当然,编写它们很简

c++ - 通用成员函数指针作为另一个类中的模板参数

我的问题类似于this.而'KarrekSB'sanswer实际上对我有所帮助。我有这些类(class):基础.h:classBase{public:Base(){}virtual~Base(){}virtualvoidinit()=0;};A1.h:#include#include"Base.h"usingnamespacestd;classA1:publicBase{public:A1(){}virtual~A1(){};virtualvoidinit(){cout我有另一个类应该能够存储具有任何类型和数量的参数的任何通用成员函数。该类看起来像这样:MFholder.h:#incl

通用方法,通用类型未知

我有很多我想转换为DTO在每个班级中,我都会做类似的事情privateListconvertsToDto(Listaddresses){ListaddressesDto=newArrayList();addresses.stream().map((address)->convertToDto(address)).forEachOrdered((addressDto)->{addressesDto.add(addressDto);});returnaddressesDto;}converttodto都会在每个类中。...但是对于convertstodto,我会放入一个抽象类,每个类都将其扩展并使

c++ - Meego应用如何添加通用导航栏?

使用MeegoTouchFramework时,标准MApplicationWindow已经附加了通用导航栏(带有切换器、菜单和关闭按钮)。例如下面的代码:#include#includeintmain(intargc,char*argv[]){MApplicationapp(argc,argv);MApplicationWindoww;w.show();returnapp.exec();}创建一个带有菜单栏的空白窗口,看起来similartothis(例如,顶部的切换器按钮、菜单和关闭按钮)。但是,由于docs不鼓励使用TouchFramework我想避免使用它,那么如何仅使用stan

c++ - 序列容器不是通用容器的子集吗?

stack没有iterator-成员类型,因此不符合一般容器要求:[container.requirements.general].但是在[container.adaptors.general]Theheadersanddefinethecontaineradaptorsqueue,priority_queue,andstack.Thesecontaineradaptorsmeettherequirementsforsequencecontainers.序列容器不是一般容器的子集吗? 最佳答案 序列容器是通用容器的一个子集。但是,序

c++ - 用 C/C++ 编写的通用代码完成框架

有没有用C/C++/C++11写的框架来写代码补全工具?或者可能有一些库允许Java或C++的代码完成(也用C++编写?)。我正在用C++为Java(不仅是Java)开发编写自定义IDE,我想以最好的方式向它添加代码完成支持,而无需重新发明weel;) 最佳答案 clang_complete是一个vim插件,用于准确完成C、C++、Objective-C和Objective-C++代码:https://github.com/Rip-Rip/clang_complete/它使用clang——一个用C++编写的开源C++编译器来完成这项

c++ - 如何使 Boost dylibs 在 os x 上通用(i386 和 x86_64)?

我正在尝试将Boost库编译成通用二进制文件(即包含i386和x86_64架构构建的“胖”文件)。破坏互联网和SO我组装了以下说明。下载boost(例如来自http://www.boost.org/users/download/)在下载的文件夹中,输入./bootstrap.sh(或者,在我的例子中./bootstrap.sh--with-libraries=thread,因为我只需要线程库)键入./b2installcxxflags="-archi386-archx86"这些步骤将Boost线程库安装到/usr/local/lib/(它的标准位置)。生成的静态库是一个通用二进制文件。

c++ - 如何将这种重用存储撤消堆栈模式从通用 vector 调整为类型化模型?

我一直在尝试完全理解SeanParent'stalk"InheritanceIsTheBaseClassofEvil"中演示的撤消模式.演讲涵盖了很多基础知识,包括C++移动语义,以及使用概念来实现多态性而不是继承,但增量撤消存储模式是我一直试图了解的模式。这是Parent在他的演讲中给出的示例的工作改编:#include#include#include#includeusingnamespacestd;templatevoiddraw(constT&x,ostream&out,size_tposition){outobject_t(Tx):self_(make_shared>(mov

通用模板 ostream << 运算符的 C++ 不明确重载

这个问题紧接我之前的问题:Genericoperator我想在哪里实现一个通用的适用于拥有to_str()的任何类的运算符方法。我已经成功地检查了一个类是否实现了to_str()方法与用途std::cout感谢这个answer.但是,我在编写模板时遇到困难ostream运营商制作std::cout有效。以下测试代码:#include#include#includetemplateusingvoid_t=void;templatestructhas_to_string:std::false_type{};templatestructhas_to_string().to_str())>>:

C++:通用 "call-functions-f-followed-by-g"方法?

是否有可能有一个通用方法接受两个函数f和g(都返回void并接受参数相同类型)并返回一个新函数,该函数接受与f和g相同类型的参数,并首先将f应用于传递的参数和然后g?具体来说,我想定义这样的东西:template//FunctionTypeisvoid(ArgType1arg1,ArgType2arg2,..)FunctionTypeCombineTwoFunctions(FunctionTypef,FunctionTypeg){//Usingthelambdasyntaxjustforillustration:return[f,g](ArgsOf(FunctionType)args)