- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 std::invoke_result_t
并且在函数中调用嵌套 lambda 时失败 auto
返回类型。这是一个复制器:
template <typename T, typename... Args>
auto print_ret_type(T &&t, Args &&... args) {
using ret_type = std::invoke_result_t<T, Args...>;
std::cout << typeid(ret_type).name() << std::endl;
}
int main(int argc, const char **argv) {
auto worker = [](int i) {
auto worker_impl = [](int i, auto &worker) {
print_ret_type(worker, i, worker);
};
worker_impl(i, worker_impl);
};
worker(10);
return 0;
}
我收到以下错误:
include/c++/9.3.0/type_traits:2783:5: error: no type named 'type' in 'std::invoke_result<(lambda at test.cpp:13:24) &, int &, (lambda at test.cpp:13:24) &>'
using invoke_result_t = typename invoke_result<_Fn, _Args...>::type;
如果我使用
void
print_ret_type
的返回类型而不是
auto
测试编译成功。我的原代码中有一个返回的模板结构,依赖于
ret_type
.谁能解释为什么我在
auto
时收到错误消息使用返回类型?
最佳答案
返回类型推导如何工作的规则有点古怪。
为了确定返回类型,它实际上实例化了函数体。此实例化中的任何错误都是硬错误。
Lambda 返回类型是隐式 ->auto
基本上;所以这些规则适用于他们。如果你想知道worker
的返回类型,每一行 worker 都必须被实例化,worker_impl
也是如此。 .
auto worker = [](int i) {
auto worker_impl = [](int i, auto &worker) {
print_ret_type(worker, i, worker);
};
worker_impl(i, worker_impl); // << worker_impl has no return type yet
};
worker(10);
要求返回类型:
template <typename T, typename... Args>
auto print_ret_type(T &&t, Args &&... args) {
using ret_type = std::invoke_result_t<T, Args...>;
此函数在
worker_impl
内部实例化确定其返回类型以确定
worker_impl
的返回类型.
->void
至
worker_impl
:
auto worker_impl = [](int i, auto &worker)->void {
然后编译,或者
print_ret_type
返回
void
.
worker_impl
的返回类型的地方,任何一个都会阻止调用结果的实例化。然而。
return
语句,一个
auto
返回体返回
void
”将是您认为使用的。但是 C++ 没有这个规则。
print_ret_type
与
worker_impl
的返回类型无关,标准(出于对编译器实现者的慷慨)让他们在那里做一些更接近“真正编译”的事情。
关于c++ - std::invoke_result 在具有自动返回类型的模板函数中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68258135/
我正在尝试使用 std::invoke_result_t并且在函数中调用嵌套 lambda 时失败 auto返回类型。这是一个复制器: template auto print_ret_type(T
给定大量采用不同类型参数的重载函数,有没有办法在编译时在模板化上下文中获取特定重载的返回类型或其中一种参数类型?例如,考虑这种情况,其中重载函数将参数引用作为输出值: struct struct_a
关于 cppreference , 据记载,std::result_of 的正确使用方式是: template std::result_of_t // instead of std::result_o
我将 GCC 7.3 与 C++17 一起使用,但我不明白为什么这一行会失败: template using X = std::invoke_result::type; 错误是: error: ty
如何为成员函数正确调用 invoke_result?或者专门针对运算符成员函数。我试过 std::invoke_result没有成功。在这种情况下,正确的语法是什么? 最佳答案 不要。使用 declt
我正在尝试执行以下操作: struct Unwrapper { template auto operator()(const T& arg, std::enable_if_t, voi
这纯粹是为了在做泛型编程时获得更多知识。如何确保作为模板参数传递给另一个函数的函数的返回类型,该函数可以采用不同数量的参数(0 到 N)。 编辑:我正在尝试使用 std::invoke_result
我想用自定义删除器声明 std::unique_ptr,它将一些参数绑定(bind)到特定函数: using namespace std::placeholders; using HandleDele
我是一名优秀的程序员,十分优秀!