std::system_category

来自cppreference.com
< cpp‎ | error
 
 
工具库
类型支持(基本类型、 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)
 
 
定义于头文件 <system_error>
const std::error_category& system_category() noexcept;
(C++11 起)

获得到为操作系统报告错误而设的静态错误类别对象的引用。要求对象覆写虚函数 std::error_category::name() 以返回指向字符串 "system" 的指针。亦要求重写虚函数 std::error_category::default_error_condition() 以映射匹配 POSIX errno 值的 error_code 到 std::generic_category

目录

[编辑] 参数

(无)

[编辑] 返回值

到导出自 std::error_category 的未指定运行时类型的静态对象的引用。

[编辑] 示例

#include <iostream>
#include <system_error>
#include <iomanip>
#include <string>
 
int main()
{
    std::error_condition econd = std::system_category().default_error_condition(EDOM);
    std::cout << "Category: " << econd.category().name() << '\n'
              << "Value: " << econd.value() << '\n'
              << "Message: " << econd.message() << '\n';
 
    econd = std::system_category().default_error_condition(10001);
    std::cout << "Category: " << econd.category().name() << '\n'
              << "Value: " << econd.value() << '\n'
              << "Message: " << econd.message() << '\n';
}

输出:

Category: generic
Value: 33
Message: Numerical argument out of domain
Category: system
Value: 10001
Message: Unknown error 10001

[编辑] 参阅

鉴别通用错误类别
(函数) [编辑]
(C++11)
列出所有标准 <cerrno> 宏常量的 std::error_condition 枚举
(类) [编辑]