如何解决=delete 方法上的限定符
当将特殊方法标记为 =delete
时,该方法的限定符是否起作用?
换句话说就是:
inline constexpr myClass(const myClass&) noexcept = delete;
和
myClass(const myClass&) = delete;
等价于?
解决方法
通常情况下,通常只是尝试并询问编译器:
class myClass {
inline constexpr myClass(const myClass&) noexcept = delete;
myClass(const myClass&) = delete;
};
int main() {
return 0;
}
1 bla.cpp|4 col 5 error| ‘myClass::myClass(const myClass&)’ cannot be overloaded with ‘constexpr myClass::myClass(const myClass&)’
2 bla.cpp|3 col 22 error| note: previous declaration ‘constexpr myClass::myClass(const myClass&)
所以是的,它们是相同的功能。你可以试试
myClass x;
auto y = x;
以确保删除了复制构造函数。这应该是有道理的 - 限定符不是新的声明,它们只是限定现有的声明。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。