微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么 vector.push_back(System::Byte) 在 VC++ 14.29 (C++/CLI) 中不再编译

如何解决为什么 vector.push_back(System::Byte) 在 VC++ 14.29 (C++/CLI) 中不再编译

我有以下代码用于编译和正常工作:

Rock rock;
rock.setWeight(3);

将 VisualStudio 更新到 16.10 版后 - 将 C++ 编译器更新到 14.29 版 - 代码产生错误

错误 C2664:'void std::vector>::push_back(const _Ty &)':无法转换 参数 1 从 'unsigned char' 到 'const _Ty &' 和 [ _Ty=无符号字符 ]

消息:gc 堆中的对象(托管数组的元素)无法转换为本机引用

消息:见 'std::vector>::push_back' 和 [ _Ty=无符号字符 ]

将循环体中的代码改为

std::vector<unsigned char> marshal_as(cli::array<System::Byte>^ const& from) 
{
    std::vector<unsigned char> result;
    result.reserve(from->Length);
    for (int i = 0; i < from->Length; i++)
    {
        result.push_back(from[i]);
    }
    return result;
}

解决问题。

我想了解此错误的原因。这是否与 C++ 20 标准的更改有关?

解决方法

这是否与 C++ 20 标准的更改有关?

没有。虽然 std::vector<>::push() 在 C++20 中发生了微妙的变化,但这并没有对这里发生的事情产生实质性影响,这个问题绝对是特定于 clr 的。

我想了解此错误的原因。

这几乎可以肯定(见下文)是一个始终存在于您的代码中的错误,但以前版本的 C++/CLI 编译器并未报告此错误。

考虑以下函数:

void foo(const int& v) {
  int* ptr = &v;
  // store ptr somewhere,long-term.
}

很明显,通过引用 gc 支持的 foo() 来调用 int 将导致灾难。然而,这正是 result.push_back(from[i]); 所做的。

您的代码“有效”,因为 push_back() 碰巧没有对其导致问题的参数执行任何操作。但是,编译器不应该知道

注意我这么说几乎是肯定的,因为我有很多时间来追踪 cli::array<T>::operator[](std::size_t) const 的调用签名。以前返回 T 而现在返回 const T% 并非不可能。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。