benxintuzi

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

/* current_exception */

exception_ptr current_exception() noexcept;

返回指向当前异常(或其副本)的智能指针【具体返回对象本身还是副本,是由具体实现库决定的】,如果当前没有异常发生,那么返回一个null-pointer。exception_ptr是一种shared smart pointer类型:只要仍然有一个exception_ptr指向它,那么被指向的exception对象必须保持有效状态,因此,可以利用exception_ptr跨线程间处理异常。

current_exception函数不抛出异常,但是如果实现该函数时,返回的是指向当前副本的指针,那么如果分配内存失败或者复制副本过程失败,将返回一个bad_exception或者一些未定义的值。

 

/* get_terminate */

terminate_handler get_terminate() noexcept;

返回终止处理函数。当没有catch语句块可以匹配时,自动调用该函数终止程序的执行。如果之前系统中没有通过set_terminate函数设置终止处理函数,那么根据不同实现系统可能返回一个abort()或者null-pointer。

 

/* get_unexpected */

unexpected_handler get_unexpected() noexcept;

当函数抛出throw列表中未声明的异常类型时,系统自动调用unexpected处理函数。如果未指定,那么该函数将返回一个unspecified value。

 

/* make_exception_ptr */

template <class E>

exception_ptr make_exception_ptr(E e) noexcept;

返回一个指向e的副本的exception_ptr对象。其行为等价于如下:

template <class E> exception_ptr make_exception_ptr (E e) noexcept {

  try {

     throw e;

  } catch(...) {

     return current_exception();

  }

}

 1 // make_exception_ptr example
 2 #include <iostream>       // std::cout
 3 #include <exception>      // std::make_exception_ptr, std::rethrow_exception
 4 #include <stdexcept>      // std::logic_error
 5 
 6 int main()
 7 {
 8     auto p = std::make_exception_ptr(std::logic_error("logic_error"));
 9 
10     try 
11     {
12         std::rethrow_exception (p);
13     } 
14     catch(const std::exception& e)
15     {
16         std::cout << "exception caught: " << e.what() << '\n';
17     }
18       
19     return 0;
20 }

 

/* rethrow_exception */

[[noreturn]] void rethrow_exception(exception_ptr p);

抛出p所指的异常对象。此时参数p不能为null exception_ptr,否则将引起未定义的行为。

 

/* set_terminate */

terminate_handler set_terminate(terminate_handler f) noexcept;

将f设置为终止处理函数。如果没有调用该函数设置f,那么系统在适当时候会调用abort()。程序中可以通过调用terminate()来显式调用当前的终止处理函数,即显式调用f或者abort()。

该函数不抛出异常,如果f是无效的或者没有被正确的实现,那么将引起未定义的行为。

 1 // set_terminate example
 2 #include <iostream>       // std::cerr
 3 #include <exception>      // std::set_terminate
 4 #include <cstdlib>        // std::abort
 5 
 6 void myterminate()
 7 {
 8   std::cerr << "terminate handler called\n";
 9   abort();  // forces abnormal termination
10 }
11 
12 int main()
13 {
14   std::set_terminate(myterminate);
15   throw 0;  // unhandled exception: calls terminate handler
16 
17   return 0;
18 }

 

/* set_unexpected */

unexpected_handler set_unexpected(unexpected_handler f) noexcept;

 

/* terminate */

[[noreturn]]void terminate() noexcept;

调用当前终止处理函数。默认情况下调用abort(),但是也可以通过set_terminate()函数来指定。

 1 // terminate example
 2 #include <iostream>       // std::cout, std::cerr
 3 #include <exception>      // std::exception, std::terminate
 4 
 5 int main()
 6 {
 7     char* p, *p2;
 8     std::cout << "Attempting to allocate 2 GB at the same point ...";
 9     try
10     {
11         p = new char[1024*1024*1024];
12         p2 = new char[1024*1024*1024];
13     }
14     catch (std::exception& e)
15     {
16         std::cerr << "ERROR: could not allocate storage\n";
17         std::terminate();
18     }
19     std::cout << "Ok\n";
20 
21     delete[] p2;
22     delete[] p;
23     return 0;
24 }

 

/* uncaught_exception */

bool uncaught_exception() noexcept;

如果已经抛出了异常,但是还没有被合适的catch语句块处理,则返回true,否则返回false。

 

/* unexpected */

[[noreturn]] void unexpected();

调用当前unexpected处理函数。默认情况下调用terminate()。但是可以通过set_unexpected()来指定。

 

/* throw_with_nested */

[[noreturn]] template <class T>

    void throw_with_nested(T&& e);

抛出一个联合了当前异常及指定e的嵌套异常。当前异常变为nested exception,而指定e变为outer exception。

 

 

posted on 2015-07-03 10:45  benxintuzi  阅读(391)  评论(0编辑  收藏  举报