通过引用转换谓词返回局部变量
Transform predicate returning local variable by reference
在下面的代码中,我试图将 std::vector<char>
复制到 std::vector<uint8_t>
中。为了避免编译器警告,我在 std::transform
的谓词中进行显式转换,而不是使用 std::copy
,就像这样
std::vector<char> buf(10, 10);
std::vector<uint8_t> u(10);
std::transform(std::begin(buf), std::end(buf), std::begin(u),
[](uint8_t val)->decltype(*std::begin(u)){
return static_cast<decltype (*std::begin(u))> (val);
});
对于这段代码,我收到编译器警告说我正在尝试通过引用 return 局部变量 val
。
为什么会这样,如何解决?
编译器是right。在 return 类型的 lambda 中:
decltype(*std::begin(u))
解引用迭代器 return 由 std::vector<T>::begin()
returns T&
或 T const&
取决于 [=20] 的 const
资格=].其次,您的 lambda 表现出未定义的行为,因为您正在 return 引用临时的 val
.
要解决您的问题,您可以使用std::decay_t
std::decay_t<decltype(*std::begin(u))>
leads 我们要:
std::transform(std::begin(buf), std::end(buf), std::begin(u),
[](auto val)-> std::decay_t<decltype(*std::begin(u))> {
return val;
});
-------------------------------------------- --------
如果类型可以隐式转换,你可以简单地做:
std::vector<uint8_t> u(std::begin(buf), std::end(buf));
或者,对于已经创建的 u
:
u.assign(std::begin(buf), std::end(buf));
另一方面,对于其他一些复杂类型,普通循环也不错:
for(const auto& k : buf)
u.emplace( k.converted() ); //Assuming you must call a conversion function
您实际上要查找的是 vector
:
的范围构造函数
std::vector<char> buf(10, 10);
std::vector<uint8_t> u(buf.begin(), buf.end());
这比涉及 transform()
.
的解决方案更有效且更易于阅读
在下面的代码中,我试图将 std::vector<char>
复制到 std::vector<uint8_t>
中。为了避免编译器警告,我在 std::transform
的谓词中进行显式转换,而不是使用 std::copy
,就像这样
std::vector<char> buf(10, 10);
std::vector<uint8_t> u(10);
std::transform(std::begin(buf), std::end(buf), std::begin(u),
[](uint8_t val)->decltype(*std::begin(u)){
return static_cast<decltype (*std::begin(u))> (val);
});
对于这段代码,我收到编译器警告说我正在尝试通过引用 return 局部变量 val
。
为什么会这样,如何解决?
编译器是right。在 return 类型的 lambda 中:
decltype(*std::begin(u))
解引用迭代器 return 由 std::vector<T>::begin()
returns T&
或 T const&
取决于 [=20] 的 const
资格=].其次,您的 lambda 表现出未定义的行为,因为您正在 return 引用临时的 val
.
要解决您的问题,您可以使用std::decay_t
std::decay_t<decltype(*std::begin(u))>
leads 我们要:
std::transform(std::begin(buf), std::end(buf), std::begin(u),
[](auto val)-> std::decay_t<decltype(*std::begin(u))> {
return val;
});
-------------------------------------------- --------
如果类型可以隐式转换,你可以简单地做:
std::vector<uint8_t> u(std::begin(buf), std::end(buf));
或者,对于已经创建的 u
:
u.assign(std::begin(buf), std::end(buf));
另一方面,对于其他一些复杂类型,普通循环也不错:
for(const auto& k : buf)
u.emplace( k.converted() ); //Assuming you must call a conversion function
您实际上要查找的是 vector
:
std::vector<char> buf(10, 10);
std::vector<uint8_t> u(buf.begin(), buf.end());
这比涉及 transform()
.