在 C 11 中,删除的函数不会完全删除,而是参与重载决策。此功能有两个主要目的。
防止隐式转换
“= delete”语法的一半效用在于禁止调用者使用特定参数调用特定函数类型。其目标是阻止特定场景下的隐式转换。对于要禁止的特定重载,它必须参与重载决策。
确保显式调用
如果“= delete”语法要完全删除该函数,它本质上相当于完全省略该声明。这将允许以下场景:
onlydouble val(20); // Legal in C++
编译器将考虑所有构造函数并识别隐式转换,允许它调用用于双参数的构造函数。
相反,使用“=”参与重载决策的“delete”:
onlydouble val(20); // Error in C++
编译器会评估所有构造函数,包括已删除的构造函数。它发现了整数文字的精确匹配,并抛出错误,因为它试图调用已删除的函数。
澄清“=删除”的角色
“ =删除”语法表示“我禁止这个”,而不仅仅是“这个不存在”。这是一个更强有力的声明,具有特定的含义。我们不需要“这不存在”的独特语法,因为它已经通过省略声明来暗示。
在极少数情况下,由于缺乏明确的方法来表明该规则,可能会出现某些规则歧义。复制构造函数不存在。然而,像复制构造函数这样的特殊构造函数是类固有的。与其说它们不存在,不如说调用它们是否合法。
结论
C 11 中删除的函数参与重载解析以方便清除错误报告并强制执行显式函数调用。这使开发人员能够防止不明确和意外的转换,确保程序的正确性和清晰度。
以上是为什么 C 11 中删除的函数会参与重载解析?的详细内容。更多信息请关注PHP中文网其他相关文章!