C++错误使用迭代器超出引用范围问题及解决方案

前言

今天在调用一个URI解析库的时候,在clang的编译器上代码能正常编译,在visual studio就提示迭代器的错误了

相关错误

cannot increment value-initialized string_view iterator
cannot dereference end string_view iterator
cannot increment string_view iterator past end
string iterator not dereferencable" you’ll get "cannot dereference string iterator because it is out of range (e.g. an end iterator)

错误截图

错误代码块

错误原因

if (end_ptr != &*auth_string.end())
{
 return { authority, uri::Error::InvalidPort, auth_string };
}

end()方法将迭代器返回到最后一个元素之后,指向字符串最后一个字符下一个位置。由于它并不指向实际的字符,因此不能对该迭代器进行解引用操作。

如果想访问最后一个元素,应该使用

  • string.end() - 1:注意,该语句仅适用于非空字符串,否则将会越界访问
  • string.back()
  • string.at(string.size() - 1)

解决方案

方法1(推荐)

if (--end_ptr != &(auth_string.back()))
{
 return { authority, uri::Error::InvalidPort, auth_string };
}

方法2

if (--end_ptr != &*--auth_string.end())
{
 return { authority, uri::Error::InvalidPort, auth_string };
}

方法3

if (--end_ptr != &(auth_string.at(auth_string.size() - 1)))
{
 return { authority, uri::Error::InvalidPort, auth_string };
}

Visual Studio 更新日志

https://learn.microsoft.com/en-us/cpp/overview/what-s-new-for-cpp-2017?view=msvc-170#visual-studio-2017-rtm-version-150

  • Minor basic_string _ITERATOR_DEBUG_LEVEL != 0 diagnostics improvements. When an IDL check gets tripped in string machinery, it will now report the specific behavior that caused the trip. For example, instead of “string iterator not dereferencable” you’ll get “cannot dereference string iterator because it is out of range (e.g. an end iterator)”.
  • 次要 basic_string_ITERATOR_DEBUG_LEVEL != 0 诊断改进。 当 IDL 检查在字符串机制中失误时,它现在会报告导致失误的特定行为。 例如,现在会收到“无法取消引用字符串迭代器,因为其已超出范围(例如末尾迭代器)”,而不是“字符串迭代器不可取消引用”。

在更新日志中已经告诉了我们错误的原因了

作者:NueXini原文地址:https://blog.csdn.net/a924282761/article/details/129700333

%s 个评论

要回复文章请先登录注册