有人可以解释为什么以下工作,尝试以下代码,它工作正常.
class A { public : int32_t temp ; A ( bool y = false ) { } } ; int main ( int argc,char *argv[] ) { A temp ; temp = new A () ; temp.temp = 5 ; std::cout << " " << temp.temp << std::endl ; return EXIT_SUCCESS; } // ---------- end of function main ----------
解决方法
在你的情况下.编译器使用了
implicitly defined Copy/Move Assignment operator.首先使用带有bool的构造函数构造A和指针.
所有指针类型在C中都是implicitly convertible到bool.有两种方法可以防止这种废话:
因此,你可以这样做:
class A { public : int32_t temp ; explicit A( bool y = false ) { } //Additionally A(void*) = delete; };
定义一个只删除void *的构造函数,在传递指针时,overload resolution的构造函数高于bool构造函数.因为只要你传递一个指针就会被重载决策选中,因为它被删除了,程序就会格式不正确.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。