繁体   English   中英

如何检查C ++中使用了哪个构造函数

[英]How to check which constructor is used in C++

我在这里修改了问题。 现在看起来像一个答案,:)。 谢谢大家解决这个问题。

我的课上有一些重载的构造函数,像这样

#include <string>

#ifdef EXPLICIT_ENUM_CONVERSION
enum struct E
#else
enum E
#endif
{
    A,
    B
};

class A
{
public:
  A(unsigned int i){};
  A(std::string const& s){};
};

以及实际上接受A作为参数的函数声明

void func(const class A& a)
{
}

但是调用者通过传递enum来调用它。

int main()    
{
#ifdef EXPLICIT_ENUM_CONVERSION
  E e=E::A;
  func((unsigned int)e);  
#else
  E e=A;
  func(e);  
#endif
}

问题:通过注释掉A(unsigned)并再次编译以获取错误,我可以知道所使用的构造函数。 但是,有没有更好的方法来说明如何从gcc命令行或objdump结果转换类型呢?

答案:如果使用-O0进行编译,然后使用objdump -CSr,则会从objdump中显示所使用的类构造函数。

问题:有什么方法可以防止用gcc将enum转换为unsigned自动转换?

答:请参阅我选择的答案。 范围枚举是在C ++ 11中引入的,可以满足目的。 您可以在EXPLICIT_ENUM_CONVERSION中检查代码。

根据您的目标,这里有3条建议:

如果您想更好地理解转换规则

  1. 阅读《 加速的C ++ 》一书中的相关部分(首选项,转换步骤)
  2. 阅读《 更有效的C ++ 》一书中的相关部分(不超过1个隐式转换)
  3. 阅读C ++标准,例如C ++ 14草案

如果您想找到一些错误

  • 使用printf调试或登录ctor
  • 或使用调试器
  • 或将您的代码分解为更小的步骤,例如

     E e; auto i = static_cast<u32>(e); func(i); 

    static_cast<u32>(e)使用显式类型的初始化器惯用语(请参阅Effective Modern C ++项目6)

如果要避免错误 ,则应避免过于复杂的隐式转换,并要警惕用户定义的转换功能( 更有效的C ++项目5)。 例如:

  • 显式转换ctor: explicit A(u32 i){};
  • 范围枚举: enum class E{...}
  • 作用域枚举作为ctor参数: A(E enumElement){};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM