"using" (typedef) 指针:它的默认构造函数返回 nullptr?
"using" (typedef) pointer : its default constructor return nullptr?
由using
轻度封装的指针的默认构造函数是否总是返回nullptr
?
换句话说,这个函数总是返回nullptr吗?
using GOID = Go_id*; //some outer scope
GOID f(){
return GOID(); //always nullptr?
}
我测试了很多次;它总是CCD_ 3。
然而,我不确定我是否幸运,或者这是C++规范。
是的,根据C++标准,使用表达式T(),其中T是指针类型,返回空指针。
这是值初始化,是的,给定指针类型,在这种情况下它将始终为零。引用链接;
值初始化的影响有:
[被编辑为与指针类型无关]。。。
4) 否则,对象为零初始化
这与typedefs无关。
指针类型的值初始化(即T()
)执行零初始化。GOID
是一个指针类型,所以你得到零。
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 为什么即使我调用参数化构造函数也会调用默认构造函数?
- 具有非默认构造函数的单例类
- 在 C++ 中声明 const 对象需要用户定义的默认构造函数.如果我有一个可变成员变量,为什么不呢?
- 如何处理没有默认构造函数但在另一个构造函数中构造的对象?
- 在C++中使用默认构造函数初始化对象的不同方法
- 在没有默认构造函数的情况下创建的派生对象
- 强制使用默认构造函数对成员进行未初始化的声明
- 使用默认构造函数初始化对象的不同方法
- 创建类类型的动态分配数组,其中类不得具有默认构造函数