2

我想防止对非 const 对象的左值引用绑定到我的函数参数,目前我有这个代码:

template <typename T>
using remove_cr = std::remove_const<typename std::remove_reference<T>::type>;

template <typename T>
using is_nc_lvalue_reference
  = std::integral_constant<bool,
      std::is_lvalue_reference<T>::value
      && !std::is_const<typename std::remove_reference<T>::type>::value
    >;

template <typename T>
void func(T && v, typename std::enable_if<
  std::is_same<THE_TYPE_I_WANT, typename remove_cr<T>::type>::value
  && !is_nc_lvalue_reference<T>::value>::type* = 0)
{
}

这对我来说似乎有很多代码,是否存在更优雅的 SFINAE 或非 SFINAE 方法?我不需要完美转发,但如果我不使用它,我会输T

这个想法是,const不应该修改对象,因此我可以将它们转换为其他表示形式并将它们提供给不同的进程。如果给出了非常量引用,它引用的对象可以被修改,但是其他进程无权访问转发进程的内存空间,因此我不转发它。

4

1 回答 1

6

这个怎么样:

template <typename T>
void func(const T &x) {
  process(x);
}

template <typename T>
void func(T &x) {
  do_nothing(x);
}

行动中的例子

于 2013-03-22T18:56:59.453 回答