googletest EXPECT_NO_THROW中没有合适的默认构造函数
No appropriate default constructor available within googletest EXPECT_NO_THROW
声明:
class ClassOne
{
ClassOne (ClassTwo* classTwo, ClassThree const& classThree);
}
测试:
ClassTwo* classTwo;
ClassThree classThree;
EXPECT_NO_THROW (ClassOne (classTwo, classThree));
这将编译并运行,但现在我将其更改为:
声明:
class ClassOne
{
ClassOne (ClassThree const& classThree);
}
测试:
ClassThree classThree;
EXPECT_NO_THROW (ClassOne (classThree));
此操作失败,并显示"没有可用的适当默认构造函数"。
以下行编译:
ClassOne classOne (classTwo, classThree); // First case
ClassOne classOne (classThree); // Second case
有什么原因为什么我不能EXPECT_NO_THROW
一个参数的构造函数吗?
我认为这是 gtest 中的一个错误(尽管我不是宏专家)。 EXPECT_NO_THROW
最终扩展到:
#define GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement)
if (::testing::internal::AlwaysTrue()) { statement; }
如果statement
括在if
正文的括号中,则使用 VS2012RC 编译代码:
#define GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement)
if (::testing::internal::AlwaysTrue()) { (statement); }
// ^ ^
作为解决方法,您可以执行以下操作:
EXPECT_NO_THROW ((ClassOne (classThree)));
你已经被C++最烦人的解析咬了。EXPECT_NO_THROW宏ClassOne (classThree)
的"语句"参数不是无名ClassOne
对象的定义,其构造函数获得名为classThree
的ClassThree
对象。它是默认构造的ClassOne
对象的声明,名为 classThree
。这与你写EXPECT_NO_THROW (ClassOne classThree);
是一样的 - 括号是可选的。
见 https://youtu.be/lkgszkPnV8g?t=1750
解决方案(如果可以使用 C++11)是使用统一初始化:
EXPECT_NO_THROW (ClassOne {classThree});
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 为什么即使我调用参数化构造函数也会调用默认构造函数?
- 具有非默认构造函数的单例类
- 在 C++ 中声明 const 对象需要用户定义的默认构造函数.如果我有一个可变成员变量,为什么不呢?
- 如何处理没有默认构造函数但在另一个构造函数中构造的对象?
- 在C++中使用默认构造函数初始化对象的不同方法
- 在没有默认构造函数的情况下创建的派生对象
- 强制使用默认构造函数对成员进行未初始化的声明
- 使用默认构造函数初始化对象的不同方法
- 创建类类型的动态分配数组,其中类不得具有默认构造函数