The C++ std:ios::operator!() function is a user defined operator that allows objects of a class to be used with the logical NOT operator(!). By implementing this operator, we can customize how the NOT operator works for the instances of that class.
For example, if an object represents a success status, operator!() might return true when the status is a failure.
SyntaxFollowing is the syntax for std::ios::operator!() function.
bool operator!() const;Parameters
It does not accept any parameter.
Return ValueIt retuns true if either failbit or badbit is set or else false.
ExceptionsIf an exception is thrown, there are no changes in the stream.
Data RacesAccesses the stream object.
Concurrent access to the same stream object may cause data races.
ExampleLet's look at the following example, where we are going to overload the operator!() function to return the negation of the boolean value.
#include <iostream> class a { public: a(bool value) : b(value) {} bool operator!() const { return !b; } private: bool b; }; int main() { a x1(true); a x2(false); std::cout << "Result Of Object1 : " << !x1 << std::endl; std::cout << "Result Of Object2 : " << !x2 << std::endl; return 0; }Output
Output of the above code is as follows −
Result Of Object1 : 0 Result Of Object2 : 1Example
Consider the following example, where we are going to check whether the object is empty or not.
#include <iostream> #include <string> class a { public: a(const std::string& c) : b(c) {} bool operator!() const { return b.empty(); } private: std::string b; }; int main() { a x1(""); a x2("TutorialsPoint"); std::cout << "Result : " << !x1 << std::endl; std::cout << "Result : " << !x2 << std::endl; return 0; }Output
Following is the output of the above code −
Result : 1 Result : 0
ios.htm
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4