模板的数据类型
Template's data-type
本文关键字:数据类型 更新时间:2023-10-16
我有一个名为Variable
的模板类,它有一个专门的char*构造函数,定义如下:
template<>
Variable<char*>::Variable(char * const &arg_value)
{
value = new char[strlen(arg_value) + 1];
strncpy(value, arg_value, strlen(arg_value));
value[strlen(arg_value)] = ' ';
}
现在,我有一个声明,它声明了一个Variable<char*>
:
Variable<char*> stringVar = const_cast<char*>("Hi");
在我的Variable
定义中,我从未向constchar*声明或定义过复制构造函数。然而,这句话做得很好。为什么会这样?我很肯定stringVar
的数据类型是Variable<char*>
,但这仍然有效。这项任务是从哪里来的?
采用一个参数的构造函数允许隐式转换。下面是一个更简单的例子:
struct Foo { Foo(int, double = 0.5, char = 'a') { } };
void bar(Foo);
Foo x = 1; // OK!
bar(2); // also OK
为了抑制这种隐含的转换,比如explicit
:
struct Eew { explicit Eew(int) { } };
// Eew e = 3; // error
Eew e2 = Eew(3); // OK but weird
Eew e3(3); // correct
Variable<char*> stringVar = const_cast<char*>("Hi");
调用类CCD_ 8的隐式c-tor。它等于
Variable<char*> stringVar = Variable<char*>(const_cast<char*>("Hi"));
您正在调用默认的复制构造函数。声明一个隐藏在您的变量<>中的变量模板并观察编译中断。
char hi[] = "Hi";
Variable<char*> stringVar = hi;
上面的第二行在语义上等价于:
Variable<char*> stringVar( implicit_cast<Variable<char*>>(hi) );
假设有implicit_cast
这样的东西执行到目标类型的类型转换,当且仅当存在可用的隐式转换。在您的案例中,构造函数:
Variable<T>::Variable( T const & )
提供了隐式转换:Variable<char*>::Variable( char * const & )
可用于从char*
转换为Variable<char*>
。
请注意,虽然在语义上会发生这种情况,但实际上副本将被删除,代码将被编译为等效的:
Variable<char*> stringVar(hi);
也就是说,在执行了所有检查之后:从hi
到类型的隐式转换是可用的,并且可以隐式调用复制构造函数。
相关文章:
- 防止主数据类型C++的隐式转换
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 在C++中打印指向不同基元数据类型的指针的内存地址
- C++浮点数据类型和字符串数据类型无法子到模板函数中
- 如何计算数据类型的范围,例如int
- C++中数据类型修饰符的顺序
- C++LinkedList问题.数据类型之间存在冲突?没有匹配的构造函数
- 特定数据类型的模板类
- 具有多个模板的模板函数,用于特定数据类型(如字符串)?
- 有没有办法提示用户使用哪种数据类型作为模板 c++
- int数据类型的指针指向的是什么,如果是一个类的私有数据成员,我们创建了该类的两个对象?
- 时间复杂度 当具有复合数据类型(如元组或对)时?
- 如何获取C++字符数据类型的地址
- 将复杂的非基元C++数据类型转换为 Erlang/Elixir 格式,以使用 NIF 导出方法
- 构造智能点数据类型以及普通数据类型的通用方法
- 如何使映射键具有两种不同的数据类型?
- 数据类型"struct seq<0, 1, 2>{}"含义是什么?
- 如何在不破坏现有应用程序的情况下更改 API 中 stl 容器的数据类型?
- Static_cast转换为错误的数据类型,但结果仍然正确?
- 使用 Boost.Spirit 解析具有混合数据类型的 OBJ 文件?