|
|
6 лет назад | |
|---|---|---|
| .. | ||
| main | 6 лет назад | |
| CMakeLists.txt | 7 лет назад | |
| Makefile | 7 лет назад | |
| README.md | 6 лет назад | |
| example_test.py | 6 лет назад | |
| sdkconfig.defaults | 6 лет назад | |
(See the README.md file in the upper level 'examples' directory for more information about examples.)
This example demonstrates usage of C++ exceptions in ESP-IDF.
By default, C++ exceptions support is disabled in ESP-IDF. It can be enabled using CONFIG_COMPILER_CXX_EXCEPTIONS configuration option.
In this example, the sdkconfig.defaults file sets the CONFIG_COMPILER_CXX_EXCEPTIONS option. This enables both compile time support (-fexceptions compiler flag) and run-time support for C++ exception handling.
The example source code declares a class which can throw exception from the constructor if the argument provided is equal to 0. This is used to demonstrate that exceptions can be thrown and caught using standard C++ facilities.
Note: Due to the use of the C++ exceptions, this example is written in C++ instead of C.
This example should be able to run on any commonly available ESP32 development board.
idf.py menuconfig
idf.py -p PORT flash monitor
(Replace PORT with the name of the serial port.)
(To exit the serial monitor, type Ctrl-].)
See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects.
app_main starting
In constructor, arg=42
In constructor, arg=0
In destructor, m_arg=42
Exception caught: Exception in constructor
app_main done