remove_reference如何禁用模板参数扣除
How remove_reference disable template argument deductions?
根据此链接,std::forward
不允许模板参数推导,而std::remove_reference
正在帮助我们实现这一点。但是使用remove_reference
是如何防止模板推导在这里发生的呢?
template <class S>
S&& forward(typename std::remove_reference<S>::type& t) noexcept
{
return static_cast<S&&>(t);
}
typename std::remove_reference<S>::type
中的S
是非推导上下文(特别是因为S
出现在使用限定id指定的类型的嵌套名称说明符中)。顾名思义,非推导上下文是指无法推导模板参数的上下文。
这个案例提供了一个简单的例子来理解为什么。假设我有:
int i;
forward(i);
S
会是什么?它可以是int
、int&
或int&&
——所有这些类型都会为函数生成正确的参数类型。编译器根本不可能确定您在这里真正指的是哪个S
,所以它不会尝试。它是不可推导的,所以你必须明确地提供你所指的S
:
forward<int&>(i); // oh, got it, you meant S=int&
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 标准对此指向成员函数类型模板参数有何说明?是我的代码有误,还是 MSVS 16.6 有问题?
- 如何根据类模板参数禁用成员函数?
- 如果t不是不可或缺的,则如何禁用非空std ::设置为函数参数
- 仅用于编译时参数禁用函数
- 如何在参数重载解析中禁用隐式转换为指向 void 的指针
- remove_reference如何禁用模板参数扣除
- 如果给定模板不是运算符参数类型的专用模板,则禁用运算符重载
- "return-by-reference"或"pass-by-reference"参数何时与constexpr兼容?
- 为什么模板参数推导被禁用 std::forward
- 如何禁用Googletest (gtest)参数化测试