C++ Tutorial Index

C++ Tutorial C++ History C++ Installation C++ First Program C++ cin and cout C++ Data type C++ Variable C++ operator C++ Keywords

C++ Control Statements

C++ If C++ Nested if C++ If-else C++ If-else-if C++ Switch C++ Break C++ Continue C++ Goto C++ For loop C++ While loop C++ Do while loop

C++ Functions

C++ Call by Value C++ Call by Reference C++ Recursion Function C++ Inline function C++ Friend function

C++ Arrays

Single dimension array Two dimension array

C++ Strings

C++ Strings

C++ Inheritance

C++ Inheritance Single level Inheritance Multilevel Inheritance Multiple Inheritance Hierarchical Inheritance Hybrid Inheritance

C++ Polymorphism

C++ Polymorphism C++ Overloading C++ Overriding C++ Virtual Function

C++ Pointers

C++ Pointers C++ this pointer

C++ Exception Handling

C++ Exception Handling

C++ Constructors

C++ Constructors Default Constructor Parameterize Constructor Copy constructor Constructor Overloading Destructor

C++ File Handling

C++ File Handling C++ Writing to file C++ Reading file C++ Close file

Miscellaneous

C Vs C++ C++ Comments C++ Data Abstraction C++ Identifier C++ Memory Management C++ Storage Classes C++ Void Pointer C++ Array To Function C++ Expressions C++ Features C++ Interfaces C++ Encapsulation std::min in C++ External merge sort in C++ Remove duplicates from sorted array in C++ Precision of floating point numbers Using these functions floor(), ceil(), trunc(), round() and setprecision() in C++ C++ References C++ Friend Functions C++ Mutable keyword Unary Operators in C++ Initialize Array of objects with parameterized constructors in C++ Differences between #define & const in C/C++ C++ Program to Implement Shell Sort C++ Program to Implement Merge Sort Storage Classes in C Vector resize() in C++ Passing by Reference Vs. Passing by the pointer in C++ Free vs delete() in C++ goto statement in C and C++ C++ program to read string using cin.getline() C++ String Concatenation Heap Sort in C++ Swap numbers in C++ Input Iterators in C++ Fibonacci Series in C++ C ++ Program: Alphabet Triangle and Number Triangle C++ Program: Matrix Multiplication C++ Program to Print Fibonacci Triangle Stack in C++ Maps in C++ Queue in C++ C++ Bitset C++ Algorithms Priority Queue in C++ C++ Multimap C++ Deque Function Pointer in C++ Sizeof() Operators in C++ C++ array of Pointers free() Vs delete in C Timsort Implementation Using C++ CPP Templates C++ Aggregation C++ Enumeration C++ Math Functions C++ Object Class C++ Queue Initialize Vector in C++ Vector in C++ C++ STL Components Function overloading in C++ C++ Maximum Index Problem C++ find missing in the second array C++ Program to find the product array puzzle C++ Program To Find Largest Subarray With 0 Sum C++ Program To Move All Zeros To The End Of The Array C++ Program to find the element that occurs once C++ Program to find the largest number formed from an array Constructor Vs Destructor C++ Namespaces C++ OOPs Concept C++ Static C++ Structs C++ Try-Catch C++ User Defined Exceptions C++ Virtual Destructor C++ vs C# Malloc() and new in C++ Palindrome Number Program in C++ Snake Code in C++ Splitting a string in C++ Structure Vs Class in C++ Virtual Function Vs Pure Virtual Function C++ Bidirectional Iterators C++ Forward Iterators C++ Iterators C++ Output Iterators C++ Range-based For Loop Converting string into integer in C++ LCM Program in C++ Type conversion in C++ Add two numbers using the function in C++ Advantage and disadvantage friend function C++ Armstrong Number Program in C++ ATM machine program in C++ using functions Binary to Decimal in C++ Bit Manipulation in C++ C++ Constructor C++ Dijkstra Algorithm Using the Priority Queue C++ int into String C++ Signal Handling Decimal to Binary in C++ Decimal to Hexadecimal in C++ Decimal to Octal in C++ Factorial Program in C++ Function in C++ Hexadecimal to Decimal in C++ Octal to Decimal in C++ Reverse a Number in C++ Structure Vs Class in C++ C++ Forward Iterators C++ Output Iterators C++ Prime number program Char Array to String in C++ Constructor Overloading in C++ Default arguments in C++ Different Ways to Compare Strings in C++ Dynamic Binding in C++ Program to convert infix to postfix expression in C++ SET Data Structure in C++ Upcasting and Downcasting in C++ Reverse an Array in C++ Fast Input and Output in C++ Delete Operator in C++ Copy elision in C++ C++ Date and Time C++ Bitwise XOR Operator Array of sets in C++ Binary Operator Overloading in C++ Binary Search in C++ Implementing the sets without C++ STL containers Scope Resolution Operator in C++ Smart pointers in C++ Types of polymorphism in C++ Exception Handling in C++ vs Java Const Keyword in C++ Type Casting in C++ Static keyword in C++ vs Java Inheritance in C++ vs Java How to concatenate two strings in C++ Programs to Print Pyramid Patterns in C++ swap() function in C++ Structure of C++ Program Stringstream in C++ and its applications rand() and srand() in C / C++ C++ Ternary Operator C++ Scope of Variables While Loop Examples in C++ Star pattern in C++ using For Loops For Loop Examples in C++ Do-While Loop Examples in C++ Top 5 IDEs for C++ That You Should Try Once Assertions in C/C++ C++ Convert Int to String Continue in C++ While loop Diamond Pattern in C++ using For Loop How to Reverse a String in C++ using Do-While Loop How to Reverse a String in C++ using For Loop How to Reverse a String in C++ using While Loop Infinite loop in C++ Loops in C++ Returning Multiple Values from a Function using Tuple and Pair in C++ wcscpy(), wcslen(), wcscmp() Functions in C++ Auto keyword in C++ C++ 11 vs C++ 14 vs C++ 17 C++ STL (Standard Template Library) Differences Between C Structures and C++ Structures Divide by Zero Exception in C++ Dynamic Constructor in C++ Dynamic Memory Allocation in C++ Find the Size of Array in C/C++ without using sizeof() function Floating Point Operations and Associativity in C, C++ and Java Hello World Program in C++ How to create a table in C++ How to Setup Environment for C++ Programming on Mac Implementation of a Falling Matrix in C++ Message Passing in C++ Pointer to Object in C++ Templates in C++ vs Generics in Java Ways to Copy a Vector in C++ What does Buffer Flush mean in C++ sort() function in C++ Structure Sorting (By Multiple Rules) in C++ Similarities between C++ and Java std::distance in C++ Array program in C++ C++ Tricks for Competitive Programming Desired Capabilities in Selenium Web Driver in C++ Socket Programming in C++ Template Specialization in C++ Classes and Objects in C++ Convex hull Algorithm in C++ DES in C++ C++ vardiac() function Difference between Two Sets in C++ Difference between Exit and Return Structured Binding in C++ Differences between Local and Global Variable Bitwise Operator vs Logical Operator Difference between OOP and POP in C++ Fork in C++ Functors in C++ How to call a void function in C++ How to create a directory or folder in C/C++ How to create a library in C++ How to create a stack in C++ How to create the Processes with Fork in C++ How to Handle Divide by Zero Exception in C++ Lambda Expression in C++ Pattern programs in C++ Roadmap to C++ Programming Substring in C++ Virtual base class in C++ Bits stdc++.h in C++ Top 14 Best Free C++ IDE (Editor & Compiler) for Windows in 2022 Bitmasking in C++ Auto Keyword in C++ Features of OOPS in C++ Hospital Management Project in C++ How to Declare Unordered Sets in C++ How to Sort an Array in C++ Include Guards in C++ Iostream in C++ Method overriding in C++ How to run program in turbo c++ How to Use Getline in C++ Leap Year Program in C++ Naming Convention in C++ New Operator in C++ Nullptr in C++ Object Slicing in C++ Principles of Object-Oriented Programming in C++ Processing strings using std string stream in C++ Pure Virtual Function in C++ With Example Program Random Number Generator in C++ Singleton Design Pattern in C++ Size_t Data Type in C++ Skyline Problem in C++ System() function in C++ Web Development in C++ Data Hiding in C++ Difference between exit() and _Exit() in C++ Hashing in C++ Object in C++ Sum of all Elements between k1’th and k2’th Smallest Elements Virtual class in C++ Vector Size in C++ Top best IDEs for C/C++ Developers in 2022 Tensorflow in C++ Sliding Window Technique in C++ Reverse String Word-Wise in C++ Returning a Function Pointer from a Function in C/C++ RTTI in C++ Pthreads or POSIX Threads in C++ Reserved Keywords in C++ Passing a Vector to a function in C++ 10 Best C and C++ Books for Beginners & Advanced Programmers Add two numbers represented by two arrays in C++ Array of Object in C++ C++ Program For FCFS Containership in C++ Counting Frequencies of Array Elements in C++ Decltype type Specifier in C++ Dynamic _Cast in C++ Difference between int main() and int main(void) in C/C++ Depth First Search Program to Traverse a Graph in C++ Features and Use Of Pointers in C/C++ Fread Function in C++ Programming Fscanf Function in The C++ Functions in C++ With Types and Examples Gmtime Function in C/C++ How is Multiset Implemented in C++ How to Build a Program in C++ How to Declare a 2d Array Dynamically in C++ inheritance Program in C++ int Max and int Min in C/C++ is It Fine to Write Void Main Or Main in C/C++ How to create a button in C++ abs() function in C++ Compile Time Polymorphism in C++ Division in C++ Factorial of a Number in C++ using while Loop Multiset in C++ 4 Pillars of OOPs Approach in C++ Backtracking Time Complexity in C++ C++ Global Variable C++ Pipe Tutorial Observer Design Pattern in C++ Private Inheritance in C++ Pthread in C++ Parameters SDL library in C++ with Examples Pointers in C++ Abstract Factory Design Pattern in C++ Ascending order in C++ How the value is passed in C++ Call by Pointer in C++ Constexpr in C++ Deadlock in C++ Design Patterns in C++ Factory Method for Designing Pattern in C++ How to calculate size of string in C++ Name Mangling and extern in C++ Preventing Object Copy in C++ Program that produces different results in C and C++ Quick Sort in C++ Single Handling in C++ Type difference of Character literals in C VS C++ Use of Inheritance in C++ User-defined literals in C++ Vector methods in C++ Void * in C and C++ Zombie and Orphan Process in C++ Isprint() in C++ List and Vector in C++ List iterators in C++ Merging Two Vectors in C++ Sleep function in C++ Stoi function in C++ String erase() in C++ String Trim in C++ When should we write own Assignment operator in C++ C++ tcp client server example C++ tcp server example Early Binding and Late Binding in C++ Factory Design Pattern in C++ Fisher-Yates shuffle algorithm in C++ For Auto in C++ Group anagrams in C++ How to convert binary string to int in C++ How to convert string to float in C++ How to remove space from string in C++ How to use pair in C++ How to use the string find() in C++ Dynamic Casting in C++ 2D Vector Initialization in C++ C++ GUI Visual Studio C++ IPC C++ Macro Function Example C++ Permutation Overloading Stream Insertion in C++ Overloading array Index operator in C++ Operators that cannot be overloaded in C++ Operator overloading in C++ isprint() function in c++ Is_trivial function in C++ Is assignment operator Inherited in C++ div() function in C++ Default Assignment Operator and References in C++ Copy Constructor vs Assignment Operator in C++ Conversion Operator in C++ Array sum in C++ STL C++ Define Macro C++ Design C++ Factory Pattern TCP Client Server Example in C++ Convert String to Uppercase in C++ exit() and _Exit() in C and C++ Initializer list in C++ Iterator invalidation in C++ Lower bound in C++ Modulus of Two float numbers or double number Pass by value in C++ Set insert function in C++ Std partition_point in C++ Unary Operator Overloading in C++ Using Default Arguments with Virtual Functions Virtual Functions and Runtime Polymorphism What is endl in C++ What is Unary Operator Overloading in C++ Which operators cannot be overloaded in C++ C++ Program to Divide the String Into N equal Parts Gray Code to Binary Code in C++ How to get the value of pi in C++ Multimap value_comp() function in C++ Vector of Vectors in C++ Naïve Bayes Algorithm in C++ Minimum Cost Path Problem in C++ 10 C++ Programming Tricks You Should Know btowc() function in C++ forward_list::cend() in C++ Unordered_multimap max_load_factor() function in C++ Cpp_int in c++ Dynamic Objects in C++ FLOCK() FUNCTION IN C++ Generate Random Double Numbers in C++ How to Assign Infinity to a Number in C++ Jump statements in C++ Multipath inheritance in C++ Out of Range Exception in C++ Size of Class in C++ Size of string in C++ std::binary_negate in c++ Thread_local in C++ Tokenizing a String in C++ Ancestors of a Node in Binary Search Tree C++ program for Double to String Conversion C++ Program to Demonstrate Use of Formatting Flags on Float Output Clamp in C++ K-Dimensional Tree in C++ Mutable Lambda in C++ Power Set in C++ Program to Find Sum of Geometric Progression Std::Back_inserter in C++ Strpbrk() function in C++ Size of int in C++ TYPES OF MANIPULATORS IN C++ Double colon in C++ How to sort vector in C++ How to use Setprecision in C++ How to write a Vector in C++ Insertion in Splay Tree in C++ Merge Sort Algorithm in C++ Printing a Character using ASCII value in C++ Regex in C++ Size of Data Types in C++ Abstract Factory Design Pattern in C++ Sqrtf() function in C++ Static Casting in C++ Using Range in Switch Case in C++ wcstoimax() and wcstoumax() function in C++ What is float in C++ What is the Diamond Problem in C++ Best way to learn C++ ios setstate() function in C++ Nested Namespace in C++ Single Inheritance in C++ std::fixed, std::scientific, std::hexfloat, std::defaultfloat in C++ StringStream in C++ for Decimal to Hexadecimal and back The OFFSETOF() macro in C++ Difference between std::next and std::advance in C++ Hiding of all overloaded methods with same name in base class in C++ C++ program to concatenate two strings using operator overloading Difference between array::fill() and array::swap() in C++ Difference between Friend Function and Virtual Function in C++ Semaphores in C++ Seekg in C++ UDP server- client implementattion in C++ What is long long in C++ CSV file management using C++ Toggle bits of a number except first and last bits in C++ Trailing Return Type C++ 11 Binary search implementation in C++ Different Versions of C++ What is Cascading in C++ Background Colour in C++ BOOL DATATYPE IN C++ BIT VECTORS IN C++

Operator overloading in C++

Operator overloading in C++ is a feature that allows users to redefine the behavior of an operator for a particular class or data type. This feature enables the developer to write code that is more readable and intuitive, making it easier to understand and maintain.

For example, consider the following code snippet, which performs a simple mathematical operation:

int x = 10;
int y = 20;
int z = x + y;

In this code, the + operator adds two integers together. However, what if you wanted to perform the same operation on two complex numbers, such as x + yi and a + bi? In this case, you would need to define a custom class for complex numbers and overload the + operator to handle the addition of complex numbers.

To overload an operator in C++, you need to use the operator keyword followed by the operator symbol. The operator overloading function must be a member function of the class, and it can be either a non-member function or a friend function.

For example, consider the following code snippet, which overloads the + operator for complex numbers:

class Complex {
  public:
    int real;
    int imag;
    
    Complex operator+(const Complex &c) {
      Complex res;
      res.real = real + c.real;
      res.imag = imag + c.imag;
      return res;
    }
};

In this code, the Complex class has two member variables, real and imag, which represent the real and imaginary parts of the complex number, respectively. The operator+ function is a member function of the Complex class that overloads the + operator. This function takes a Complex object as an argument and returns the result of the addition operation.

Here's an example of how you can use the overloaded + operator:

Complex c1, c2, c3;
c1.real = 1;
c1.imag = 2;
c2.real = 3;
c2.imag = 4;
c3 = c1 + c2;

In this code, two Complex objects, c1 and c2, are created, and their real and imaginary parts are initialized. The + operator adds c1 and c2 together, and the result is stored in c3.

For example, the overloaded operator must have the same precedence and associativity as the original operator, and the number and types of operands must be the same.

It is important to note that operator overloading should be used with caution, as it can lead to code that is difficult to understand and maintain. For example, overloading the + operator for string concatenation is a common use case, but it can lead to unexpected behavior if the programmer is unaware that the + operator has been overloaded.

Can we overload all operators?

Some operators, such as the conditional operator (? :), cannot be overloaded, while others, such as the unary & operator, can only be overloaded as non-member functions.

Additionally, some operators, such as the subscript operator ([]) and the function call operator (()), can only be overloaded as member functions of a class. The precise rules and restrictions for overloading each operator are defined by the language and can be found in the C++ standard.

Operators that can be Overloaded:

In C++, the following operators can be overloaded:

  1. Arithmetic Operators: +, -, *, /, %
  2. Relational Operators: ==, !=, <, >, <=, >=
  3. Logical Operators: &&, ||, !
  4. Bitwise Operators: &, |, ^, ~, <<, >>
  5. Assignment Operators: =, +=, -=, *=, /=, %=, &=, |=, ^=, <<=, >>=
  6. Increment and Decrement Operators: ++, --
  7. Pointer Operators: &, *
  8. Subscript Operators: []
  9. Function Call Operators: ()
  10. Member Access Operators: ., ->
  11. Class Member Access Operators: .*, ->*
  12. Conversion Operators: type operator new_type()

It is important to note that not all operators can be overloaded for all types of objects. For example, the conditional operator (? :) cannot be overloaded, while the function call operator (()) can only be overloaded as a member function of a class. Additionally, some operators, such as the unary & operator, can only be overloaded as non-member functions. When overloading operators, it is important to understand the limitations and restrictions of each operator to ensure that the overloads are defined correctly.

Important points about operator overloading:

  • Consistency: Overloaded operators should behave consistently, and intuitively that is consistent with the behavior of the corresponding operator on built-in types.
  • Precision: Overloaded operators should be implemented with a high degree of precision and accuracy to avoid any unexpected or incorrect results.
  • Associativity: The associativity of an operator should be taken into consideration when overloading it, especially for operators that have different behavior for different types of objects.
  • Symmetry: For binary operators, the order of the operands should not matter. The operator should produce the same result regardless of the order in which the operands are applied.
  • Overloading of Complex Operators: Complex operators, such as the subscript operator ([]) and the function call operator (()), can be more challenging to overload correctly and require a deeper understanding of C++.
  • Side Effects: Operator overloading should not have any side effects, such as modifying the state of objects or causing exceptions to be thrown.
  • Exception Safety: Operator overloading should be exception-safe, meaning that it should not leave the program in an undefined state if an exception is thrown.
  • Operator Precedence: Overloaded operators should respect the operator precedence and associativity rules defined by the language.
  • Compatibility: Overloaded operators should be compatible with C++ features, such as templates and inheritance.
  • Compatibility with Standard Library: Overloaded operators should be compatible with the Standard Library so that they can be used in conjunction with the algorithms and data structures provided by the library.

Program:

Here's a complete program that demonstrates operator overloading in C++:

#include <iostream>


class Complex {
  public:
    int real;
    int imag;


    Complex operator+(const Complex &c) {
      Complex res;
      res.real = real + c.real;
      res.imag = imag + c.imag;
      return res;
    }


    friend std::ostream& operator<<(std::ostream &out, const Complex &c) {
      out << c.real << " + " << c.imag << "i";
      return out;
    }
};


int main() {
  Complex c1, c2, c3;
  c1.real = 1;
  c1.imag = 2;
  c2.real = 3;
  c2.imag = 4;
  c3 = c1 + c2;
  std::cout << c3 << std::endl;
  return 0;
}

Explanation:

  • This program demonstrates operator overloading in C++. The program defines a class called Complex, which represents complex numbers. The class has two member variables, real and imag, which represent the real and imaginary parts of a complex number, respectively.
  • The Complex class overloads the + operator by defining a member function called operator+ that takes a Complex object as an argument and returns a new Complex object that is the result of adding the two complex numbers. The operator overload uses the real and imag member variables of both objects to perform the addition.
  • The class also overloads the << operator by defining a friend function called operator<< that takes a std::ostream object and a Complex object as arguments. The function outputs the real and imaginary parts of the Complex object to the output stream and returns the output stream.
  • In the main function, three Complex objects, c1, c2, and c3 are created. The real and imag member variables of c1 and c2 are initialized with values. The c3 object is then assigned the result of c1 + c2 using the overloaded + operator. Finally, the c3 object is output to the console using the overloaded << operator.
  • The output of this program will be 4 + 6i, which represents the result of adding the two complex numbers 1 + 2i and 3 + 4i.

Program output:

Operator overloading in C++

Program:

Here's another example program that demonstrates operator overloading in C++:

#include <iostream>


class Vector {
  public:
    int x;
    int y;


    Vector operator+(const Vector &v) {
      Vector res;
      res.x = x + v.x;
      res.y = y + v.y;
      return res;
    }
};


int main() {
  Vector v1, v2, v3;
  v1.x = 1;
  v1.y = 2;
  v2.x = 3;
  v2.y = 4;
  v3 = v1 + v2;-
  std::cout << v3.x << " " << v3.y << std::endl;
  return 0;
}

Explanation:

  • This program demonstrates the concept of operator overloading in C++. The program defines a class Vector that represents a two-dimensional vector in a Cartesian coordinate system.
  • The Vector class has two member variables, x, and y, that represent the x and y components of the vector, respectively. The program overloads the + operator for the Vector class, allowing two Vector objects to be added together.
  • The operator+ function is a member function of the Vector class and takes a constant reference to another Vector object as an argument. The function returns a new Vector object that represents the sum of the two vectors.
  • The operator+ function adds the x and y components of the two vectors and returns the result as a new Vector object.
  • In the main function, three Vector objects, v1, v2, and v3, are declared. The x and y components of v1 and v2 are initialized, and v3 is assigned the result of adding v1 and v2 using the overloaded + operator.
  • Finally, the x and y components of v3 are output to the standard output stream using the cout statement.
  • The output of this program will be 4 6, which represents the result of adding the two vectors 1 2 and 3 4.

Program Output:

Operator overloading in C++

Conclusion:

In conclusion, operator overloading in C++ provides a powerful tool for customizing the behavior of operators for specific data types.

When overloading operators, it is important to understand the limitations and restrictions of each operator and to implement the overloads consistently and intuitively with respect to the rules and conventions of the language.

When used correctly, it can make code more readable and intuitive, making it easier to understand and maintain. However, it should be used with caution to avoid unintended consequences.