草庐IT

Duck-typing

全部标签

c++ - 使用类型删除创建运行时 type_traits 查询

是否有可能使用类型删除来创建封装任意类型的对象(我们称之为ErasedType),并且可以在运行时查询以判断是否存在另一个任意类型T可转换为ErasedType?考虑之后,我不认为这是可能的-尽管看起来它在理论上可能是可能的。编译器会知道哪些类型T我们正在尝试与ErasedType进行比较,因此可以在运行前生成必要的代码。问题是,在实践中,似乎没有任何方法可以将模板参数类型从基类实例传递到子类实例。例如:structFooBase{templateboolis_convertible(){returncall_derived();}protected:virtualboolcall_d

c++ value_type 不适用于 std::map 中的 std::tr1:tuple

以下代码片段适用于VisualStudio2008,但不适用于VisualStudio2010。templatestructMyStruct{typedefstd::mapKeys;MyStruct(){}voidset(TKey&key){#if1//ThisworkswithVS2008butnotwith2010keys_.insert(typenameKeys::value_type(key,1));#else//ThisworkswithVS2008andVS2010keys_.insert(std::pair(key,1));#endif};private:Keyskeys

c++ - 干净地抑制 gcc 的 `final` 建议警告 (`-Wsuggest-final-types` 和 `-Wsuggest-final-methods` )

我喜欢使用-Wsuggest-final-types编译我的代码和-Wsuggest-final-methods以便在可能使用final关键字以允许编译器更积极地优化的机会时收到警告。不过,有时这些建议是不正确的-例如,我有一个类Base和一个virtual~Base()析构函数,在另一个项目中以多态方式使用,gcc建议我可以将Base标记为final。有没有办法“干净地”告诉编译器Base是多态使用的,不应该被标记为final?我能想到的唯一方法是使用#pragma指令,但我发现它会使代码困惑且难以阅读。理想情况下,我正在寻找可以添加到类/方法声明前/后的非最终关键字或属性。

c++ - 错误 C2011 : 'MSXML2::IXMLDOMImplementation' : 'struct' type redefinition

我正在更改我的C++项目,该项目之前在VC6中,现在正在迁移到VS2008,以使用MSXML6而不是早期的MSXML3。当代码在VC6中时,我们通过导入它来使用MSXML3#import"msxml3.dll"这被替换为#import"msxml6.dll"在此之后,当我编译项目时,我得到了这个和其他几个类似的错误错误C2011:“MSXML2::IXMLDOMImplementation”:“结构”类型重新定义以上错误在msxml3.tlh文件中。1)为什么仍然使用msxml3?2)我将问题缩小到MSXML.h,它以某种方式自动包含在我的项目中。为什么是这样?3)MSXML.h中引用

c++ - boost type_traits is_array

我一直在尝试浏览Boosttype-traitsheader,考虑到无数#define提供的强烈不可读性,现在我感到非常恶心。然后是更多#define。具体来说,我有兴趣弄清楚以下3个特征:类型T是数组、类还是枚举。任何人都可以帮助建议一些破译明显疯狂背后的方法的方法吗?比如你如何从一个类型中找出特征背后的理论,任何相关的阅读Material等。 最佳答案 is_array非常简单直接:templatestructis_array{staticconstboolvalue=false;};templatestructis_array

C++ 缓存友好方式访问 `vector <struct_type>` 的所有元素的所有成员

我有兴趣针对多线程计算优化我的代码。在缓存、流水线或内存访问的任何其他方面,以下比较如何节省这些资源:案例一structsomething{floata;floatb;intc;boold;};vectorvec(n,something());for(intq=0;q案例二structsomething{floata;floatb;intc;boold;};vectorvec(n,something());for(intq=0;q案例三vectora(n);vectorb(n);vectorc(n);vectord(n);for(intq=0;q此外,是否有更好的方法来解决上述问题?

c++ - 错误 : no type named ‘value_type’ in ‘class

我收到以下编译器错误:(graph_algorithms.h:59:111:error:notypenamed‘value_type’in‘classGraph::graph_algorithms::vertex_comparer’)这是什么意思?下一行给了我一大堆编译器错误std::priority_queue::vertex,typenameGraph::graph_algorithms::vertex_comparer>pri_que;#ifndefGRAPH_ALGORIUHMS_H_#defineGRAPH_ALGORIUHMS_H_#include#include"grap

c++ - 非类型模板参数错误 ('x' is not a type)

我正在尝试构建我friend的QT应用程序的OSX版本,他已经在Windows和Linux上构建了该应用程序。我们都在使用g++。我正在使用gcc4.2.1。不幸的是,我不知道他在构建应用程序时使用的是什么版本(这是很久以前的事了)。谁能解释一下为什么我会收到错误:../../../src/dbapi/dbcore/node.h:24:error:'dimensions'isnotatype编译以下代码时:节点.h:templateclassEXPORT_DBCORENode:publicTransform{public:Node(Idid,QString&name,QString&t

c++ - boost::单位::数量 "incomplete type"错误

我正在尝试在项目中使用boost::units但遇到了麻烦。我有一个模板类,其中有一些quantity对象作为成员。在一个中,我希望存储一个具有压力维度的值,所以我有quantitypress;声明为成员变量。然而,这给出了一个错误,指出quantity需要两个模板参数(源代码显示第二个模板参数应该默认为double)。如果我然后指定quantitypress;相反,我得到一个错误,上面写着错误:字段“press”的类型不完整。是我做错了什么还是压力的执行有问题?最小示例:#include#includeusingnamespaceboost::units;usingnamespace

c++ - 保证 std::container::size_type 是一个 std::size_t

正在关注thisquestion,我决定使用std::size_t作为size_type对于每个容器,出于明显的可读性原因。我知道这在理论上是可能的std::container::size_type不是std::size_t,但我认为我当前和future的配置并非如此。但是,为了避免恶意错误,我在使用它们时会检查类型是否相同。例如:BOOST_STATIC_ASSERT(boost::is_same::size_type,std::size_t>::value);std::vectorx;/*fillx*/for(std::size_ti=0;i代码的另一个地方,我使用了一个std::