为什么结构可以隐式转换以匹配函数的参数类型,但如果它是删除了默认赋值运算符的赋值运算符,则不能?



示例:

struct c{
    void operator=(bool){}
    operator bool(){
        return false;
    }
    c&operator=(const c&)=delete;
};
void f(bool){}
int main(){
    c a,b;
    f(b); //works fine
    a=b;  //g++ -std=c++17 says: error: use of deleted function ‘c& c::operator=(const c&)’
}

为什么f(b)调用将b转换为bool以匹配f的类型,而a=b坚持不转换?

重载解析的工作原理是找到最佳匹配,然后检查函数的可访问性。如果您无法访问该函数,因为它是受保护的/私有的或已删除的,则会出现错误。带

f(b);

唯一有效的选项是CCD_ 6,因此代码可以工作。带

a=b

编译器找到

c&operator=(const c&)
// and the chain
operator bool() -> void operator=(bool) 

第一个是更好的匹配,所以它是使用的重载,并且由于它被标记为delete,所以会出现编译器错误。

相关内容

最新更新