I am learning C++ and I am experiencing when I try and create my own exception and throw them on Linux.
I've created a small test project to test my implementation and below is my exception class header file.
class TestClass : public std::runtime_error { public: TestClass(char const* const message) throw(); virtual char const* what() const throw(); };
The source file for the exception class is
using namespace std; TestClass::TestClass(char const* const message) throw() : std::runtime_error(message) { } char const * TestClass::what() const throw() { return exception::what(); }
In my main app, I am calling a function which throws my exception and catches it in a try/catch as follows:
void runAFunctionAndthrow(); /* * */ int main(int argc, char** argv) { try { cout << "About to call function" << endl; runAFunctionAndthrow(); } catch (TestClass ex) { cout << "Exception Caught: " << ex.what() << endl; } return 0; } void runAFunctionAndthrow() { cout << "going to run now. oh dear I need to throw an exception" << endl; stringstream logstream; logstream << "This is my exception error. :("; throw TestClass(logstream.str().c_str()); }
When I run I'm expecting to get the following output:
About to call function
Going to run now. oh dear I need to throw an exception
Exception Caught: This is my exception error. :(
Instead what I am getting is
About to call function
going to run now. oh dear I need to throw an exception
Exception Caught: std::exception
Notice the last line it says std::exception instead of my actual exception message "This is my exception error".
Why is this, it works OK on Windows but on Linux it does this.
From what I've seen on various posts what I've done is correct so what am I missing.
Custom exceptions can be used to add clear, meaningful, and user-friendly information to exceptions when errors occur while your program is running. The base class for all exceptions in . Net is Exception . All of the classes in the exception hierarchy derive directly or indirectly from this class.
C# includes the built-in exception types such as NullReferenceException , MemoryOverflowException , etc. However, you often like to raise an exception when the business rule of your application gets violated. So, for this, you can create a custom exception class by deriving the ApplicationException class.
Custom exceptions provide relevant information about an error to the exception handling mechanism. They can be generated by creating a new class containing the attributes needed and throwing an instance of such a class, or by inheriting from std::exception and overriding the what() function.
Your what()
returns:
return exception::what();
The return value from std::exception::what()
is specified as follows:
Pointer to a null-terminated string with explanatory information.
That's it. Nothing more, nothing else. The text you're showing certainly qualifies as an "explanatory information". And this is the only requirement for the return value of what()
(except for one other one which is not germane here).
In other words, C++ does not guarantee the exact contents of what you get with what()
. what()
you see is what()
you get, as the saying goes.
If you want your exception to describe itself, in some way, it's up to you to implement that, as part of your what()
.
You need your own implementation of what() method or use std::runtime_error::what()
as written in comments
Say:
class TestClass : public std::runtime_error { std::string what_message; public: const char* what() override { return what_message.c_str(); } };
Also, better use noexcept
instead of throw()
and only after you read about them - link.
And in your try-catch:
catch (const TestClass& myException)
Instead of catch(TestClass myException)
- otherwise you do an implicit copy which can potentially result in an exception throw. It also breaks the polymorphism: if you want to catch
pure virtual interface
implementation instance, you would need to use a reference.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With