std::bad_array_new_length

来自cppreference.com
< cpp‎ | memory‎ | new
 
 
工具库
类型支持(基本类型、 RTTI 、类型特性)
动态内存管理
错误处理
程序工具
变参数函数
日期和时间
函数对象
(C++11)
关系运算符
optionalanyvariant (C++17)
pair 与 tuple
(C++11)
(C++17)
swap 、 forward 与 move
(C++14)
(C++11)
(C++11)
初等字符串转换
(C++17)
(C++17)
类型运算
(C++11)
(C++17)
 
动态内存管理
 
 
 
定义于头文件 <new>
class bad_array_new_length;
(C++11 起)

std::bad_array_new_lengthnew 表达式作为异常抛出以报告非法数组长度的对象类型,若

1) 数组长度为负

2) 新数组的总大小将超过实现定义最大值

3) 初始化器子句的数量超出要初始化的元素数量

仅数组第一维可生成此异常;第一维外的维数是常量表达式,在编译时得到检查。

cpp/error/exceptioncpp/memory/new/bad allocstd-bad array new length-inheritance.svg
关于这幅图像

继承图

目录

[编辑] 成员函数

构造 bad_array_new_length 对象
(公开成员函数)

继承自 std::bad_alloc

继承自 std::exception

成员函数

析构该异常对象
(std::exception 的虚公开成员函数) [编辑]
[虚]
返回解释性字符串
(std::exception 的虚公开成员函数) [编辑]

[编辑] 注意

可提供但不要求虚成员函数 what() 的覆写。

[编辑] 示例

应抛出 std::bad_array_new_length 的三种条件:

#include <iostream>
#include <new>
#include <climits>
 
int main()
{
    int negative = -1;
    int small = 1;
    int large = INT_MAX;
    try {
        new int[negative];           // 负大小
        new int[small]{1,2,3};       // 过多初始化器
        new int[large][1000000];     // 过大
    } catch(const std::bad_array_new_length &e) {
        std::cout << e.what() << '\n';
    }
}


[编辑] 参阅

分配函数
(函数) [编辑]
内存分配失败时抛出的异常
(类) [编辑]