MISRA C++:2008 Rule 15-1-3
An empty throw (throw;) shall only be used in the compound- statement of a catch handler
Description
Rule Definition
An empty throw (throw;) shall only be used in the compound- statement of a catch handler.1
Rationale
When you use an empty throw statement (throw;), the compiler
                checks if an exception object is present in the current scope. If the current scope
                contains an exception object, the compiler raises a temporary object containing the
                current exception. If the current scope does not contain an exception objects, the
                compiler invokes std::terminate() implicitly. The function
                    std::terminate() terminates the program execution in an
                implementation-defined manner. That is, the exact process of program termination
                depends on the software and hardware that you are using. For instance,
                    std:terminate() might invoke std::abort()
                to abnormally abort the execution without unwinding the stack, leading to resource
                leak and security vulnerabilities.
The best practice is to use an empty throw statement only in the
                    catch block of a try-catch construct,
                which enables you to spread the handling of an exception across multiple catch
                blocks. Avoid using empty throw statements in scopes that might not contain an
                exception.
Polyspace Implementation
Polyspace® flags an empty throw statement if it is not within a catch block.
Troubleshooting
If you expect a rule violation but Polyspace does not report it, see Diagnose Why Coding Standard Violations Do Not Appear as Expected.
Examples
Check Information
| Group: Exception Handling | 
| Category: Required | 
Version History
Introduced in R2013b
1 All MISRA coding rules and directives are © Copyright The MISRA Consortium Limited 2021.
The MISRA coding standards referenced in the Polyspace Bug Finder™ documentation are from the following MISRA standards:
- MISRA C:2004 
- MISRA C:2012 
- MISRA C:2023 
- MISRA C++:2008 
- MISRA C++:2023 
MISRA and MISRA C are registered trademarks of The MISRA Consortium Limited 2021.