草庐IT

is_same_template

全部标签

c++ - 模板类中的模板函数 is_same

为什么这段代码会产生错误的输出?//this-type.cpp#include#includeusingnamespacestd;templateclassA{public:A(){cout>::value{};intmain(){Bb;}输出:$g++-std=c++11this-type.cpp$./a.outfalseA到B中的“*this”的类型是A,不是吗? 最佳答案 *this是A类型的左值,因此decltype(*this)将给出引用类型A&。回想一下左值上的decltype给出了引用类型:cout>::value&>

c++ - 将 ifstream 转换为 bool 和使用 ifstream::is_open() 之间的区别

也许是个伪问题,但我需要一个明确的答案。这些函数的返回有什么不同吗intFileExists(conststd::string&filename){ifstreamfile(filename.c_str());return!!file;}intFileExists(conststd::string&filename){ifstreamfile(filename.c_str());returnfile.is_open();}所以换句话说,我的问题是:将fstream转换为bool会给出与fstream::is_open()完全相同的结果吗>? 最佳答案

c++: 'std::is_fundamental' 的替代方案?

在模板类中的函数中,我试图区分基本类型和其他类型。在C++11中你可以这样做:if(std::is_fundamental::value){//Treatitasaprimitive}else{//Treatitotherwise}如果我错了,请纠正我,这不仅在C++11中。在早期版本的c++中是否有替代方案? 最佳答案 你可以使用Boost'stypetraits在C++03中是这样的:#include...if(boost::is_fundamental::value){//Treatitasaprimitive}else{//

c++ - 在每个源文件中替代 "extern template"

我正在开发一个库,其中我们的许多核心对象都是模板,其中一个特定实例以指向该模板实例的智能指针的形式出现在项目的大多数文件中。我在单个源文件中明确实例化了这些模板。我们最近切换到C++11,我正在尝试使用新的externtemplateclassMyTemplate;加快编译速度。我的第一个问题是我是否在周围使用智能指针MyTemplate正在隐式实例化模板并要求文件顶部的“外部模板..”以避免重复实例化。我的第二个问题是是否有一些替代方法来添加所有这些externtemplateclassMyTemplate;到每个源文件。为我定义的每个模板搜索智能指针的每个实例并确保我在该文件中有正

C++ : Check if the template type is one of the variadic template types

这个问题在这里已经有了答案:Checkifatypeispassedinvariadictemplateparameterpack(3个答案)关闭7年前。假设我们有函数:templatevoidfoo(){...};检查“Kind”类型是否是C++(包括C++1z)中的“Kinds”类型之一的最简单方法是什么?

c++ - 数组的地址 VS 指针到指针 : Not the same?

我在处理指针时遇到了一个问题。到目前为止,我知道当我们创建任何数据类型的数组时,数组的名称实际上是一个指向数组第一个索引的指针(可能是静态指针)。对吗?所以我想要实现的是创建另一个指针,它可以保存数组名称的地址(即指向另一个指针的指针,在我的例子中是数组名称)例如:charname[]="ABCD";//nameholdingtheaddressofname[0]char*ptr1=name;//Whenthisispossiblechar**ptr2=&name;//Whynotthis.Itgivemeerrorthatcannotconvertchar(*)[5]tochar**

c++ - 继承与聚合以及 "has-a"与 "is-a"。

在我的代码中,我发现使用类似混合的继承来组合具有不同block的对象很有用。我有:className{public:typedefint32_tvalue_type;public://ctorsanddtorsvoidset_value(value_typevalue){value_=value;}constvalue_type&value()const{returnvalue_;}private:value_typevalue_;};classNamedObject{public:voidset_name(constName&name){name_=name;}constName&n

c++ - 语句 "a class is an object even if not instantiated"是什么意思?

我是一名学习Ruby的C++程序员。在一本初学者书中,我读到:“一个类本身就是一个对象,即使您不直接实例化它也是如此。”我不知道怎么解释。 最佳答案 在C++中,除了typeid等,类没有语言可见的运行时表示。你可以说classFoo{};,但你不能说&Foo。(您可以获取typeinfo对象的typeid/地址,它是类对象的SCSS版本)。在Ruby中,类是对象。任何你能用一个对象做的事情,你都可以用一个类来做,因为它是一个对象。例如,在Ruby中,您可以foo.send(...)到任何对象foo。由于类是一个对象,因此您也可以使

c++ - 添加虚拟删除错误 : type 'base' is not a direct base of derived class

考虑以下示例代码:#includeusingnamespacestd;classbase{public:base(){cout这给出了错误:error:type`base'isnotadirectbaseof`derived2'为什么会出现这个错误?如果我将基类设为虚拟,则错误不再存在。这是什么原因? 最佳答案 因为base不是derived2的直接基类。您必须为您的直接基础提供构造函数,在本例中为derived1。虚拟基地除外。它们总是在叶类中初始化,否则您可能会为同一个基类调用多个构造函数。因此,如果您使base成为虚拟的,您不

c++ - std::map.insert "could not deduce template argument for..."

我正在尝试熟悉STL库,但我无法理解我的编译错误。我使用编译器错误字符串“无法推断...的模板参数”搜索了其他问题,但没有一个答案似乎适用或相关。Error4errorC2784:'boolstd::operator&,conststd::unique_ptr&)':couldnotdeducetemplateargumentfor'conststd::unique_ptr&'from'conststd::string'c:\programfiles(x86)\microsoftvisualstudio10.0\vc\include\xfunctional125我正在编写一个简单的解释