关于C++标准异常之std::out_of_range

简介

定义于头文件 <stdexcept>
   
class out_of_range;
 

定义要作为异常引发的对象类型。它报告试图访问定义范围之外的元素所导致的错误。它可以由std::bitset和std::basic_string的成员函数、std::stoi和std::stod函数族以及边界检查的成员访问函数(例如std::vector::at和std::map::at)抛出。
继承关系如下:

 

成员函数

Member functions

(constructor)
constructs a new out_of_range object with the given message
(public member function)
operator=
replaces the out_of_range object
(public member function)
what
returns the explanatory string
(public member function)

std::out_of_range::out_of_range

out_of_range( const std::string& what_arg );
(1)  
out_of_range( const char* what_arg );
(2) (since C++11)
  (3)  
out_of_range( const out_of_range& other );
(until C++11)
out_of_range( const out_of_range& other ) noexcept;
(since C++11)
     
1-2) Constructs the exception object with what_arg as explanatory string that can be accessed through what().
3) Copy constructor. If *this and other both have dynamic type std::out_of_range then std::strcmp(what(), other.what()) == 0. (since C++11)

Parameters

what_arg - explanatory string
other - another exception object to copy

Exceptions

1-2) May throw std::bad_alloc

Notes

Because copying std::out_of_range is not permitted to throw exceptions, this message is typically stored internally as a separately-allocated reference-counted string. This is also why there is no constructor taking std::string&&: it would have to copy the content anyway.

std::out_of_range::operator=

out_of_range& operator=( const out_of_range& other );
  (until C++11)
out_of_range& operator=( const out_of_range& other ) noexcept;
  (since C++11)
     

Assigns the contents of other. If *this and other both have dynamic type std::out_of_range then std::strcmp(what(), other.what()) == 0 after assignment. (since C++11)

Parameters

other - another exception object to assign

Return value

*this

std::out_of_range::what

virtual const char* what() const throw();
  (until C++11)
virtual const char* what() const noexcept;
  (since C++11)
     

Returns the explanatory string.

Parameters

(none)

Return value

Pointer to a null-terminated string with explanatory information.

Notes

Implementations are allowed but not required to override what().

 

posted on   活着的虫子  阅读(13676)  评论(0编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示