c++ - 通过引用转换谓词返回局部变量

标签 c++ c++11 lambda stl std

在下面的代码中,我试图复制一个 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);                              
     });    

对于这段代码,我收到编译器警告说我正在尝试返回一个局部变量 val通过引用。

为什么会这样,如何解决?

最佳答案

编译器是right .在您的 lambda 的返回类型中:

decltype(*std::begin(u))

解引用 std::vector<T>::begin() 返回的迭代器返回 T&T const&取决于 const u资质.其次,您的 lambda 表现出未定义行为,因为您正在返回对临时 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

关于c++ - 通过引用转换谓词返回局部变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38986471/

相关文章:

vb.net - VB.NET 中的异步 lambda 表达式

C++使用promise,future从线程返回多个值?

c++ - 使用空参数包显式调用可变函数模板

c++ - 将对象变量作为 const ..&

C++ Windows 添加选项到菜单

c++ - 递归类型的判别 union

c++ - 如何编写看起来像方法的 lambda 表达式?

c++ - 如何将函数的指针从std::function传递给Linux克隆?

c++ - 定义和播种具有全局范围的伪随机数生成器 (C++)

C++ gdb 错误读取变量 : Cannot access memory at address