SFINAE - 如果参数是可复制构造的,则启用一个函数,否则启用另一个函数

问题描述

如果参数是可复制构造的,我希望调用一个函数和另一个函数(类似于前面的但有额外的代码)。我发现 std::is_copy_constructible 没有按预期工作

#include <iostream>

using namespace std;


struct Nocopy {
    int n;
    Nocopy(const Nocopy&) = delete;
};


template <typename T,typename U,std::enable_if_t<!std::is_copy_constructible_v<U>,int> = 0>
void log_debug(T&& t,U&& u)
{
    
 std::cout<<"\n"<<typeid(U).name()<<" does not have copy constructor; ";  
}
   
   
template <typename T,std::enable_if_t<std::is_copy_constructible_v<U>,U&& u)
{
    
 std::cout<<"\n"<<typeid(U).name()<<" has copy constructor; ";  
}

int main()
{
    Nocopy a{2};
    log_debug("value is ",a);
    
    std::cout<<"\nstd::is_nothrow_copy_constructible_v  "<<std::is_copy_constructible_v<Nocopy>;  //returns 0 as expected

    return 0;
}


                                                                                                                                                                                                                                    

输出

6Nocopy 有拷贝构造函数
std::is_copy_constructible_v 0

is_copy_constructible_v 似乎在 main 函数内部工作,但不在外部

解决方法

问题是这里的 master 不是推导出为 U,而是推导出为 NoCopy

您可以通过在 NoCopy& 中使用 std::decay_t<U> 来解决此问题,以按照您的需要去除 cv 限定符和引用并产生 enable_if

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...