Operator Overloading in C++
Operator Overloading in C++
Operator Overloading in C++
Compile-time Polymorphism
Dr. K. Veningston
Department of Computer Science and Engineering
National Institute of Technology Srinagar
veningstonk@nitsri.ac.in
Quick Recap
• Encapsulation
– Encapsulation binds the data & functions together into one single unit (class),
which keeps both safe from outside interference.
• Data encapsulation leads to data hiding.
– Data hiding is a concept in OOP which confirms the security of members of a
class from unauthorized access
– Data hiding using access specifiers (public, private, protected) from outside
world.
• Data hiding is a technique of protecting the data members from being manipulated or hacked
from any other source.
– Data hiding also reduces some complexity of the system.
• Data hiding can be achieved through the encapsulation, as encapsulation is a subprocess of
data hiding.
• Data hiding guarantees restricted data access to class member & maintain object integrity.
Quick Recap
• Abstraction
– Abstraction is primarily used to hide the complexity.
– It indicates the necessary characteristics of an object that differentiates it
from all other types of objects.
– An abstraction concentrates on the external aspect of an object.
• For an object, abstraction provides the separation of the crucial behaviour from its
implementation.
– A proper abstraction emphasizes on the details that are important for the
reader or user and suppresses features that are irrelevant and deviant.
– Every real-world entity has a certain level of abstraction.
• Hiding the details of a particular method.
• Example: Laptop functionalities
Quick Recap
• Data hiding vs. Encapsulation vs. Abstraction
Basis Data hiding Encapsulation Abstraction
Definition Hides the data from the Encapsulation concerns Extracts only relevant
parts of the program about wrapping data to information and ignore
hide the complexity of a inessential details
system
• Note:
– All the operators in C++ can be overloaded except 4 operators.
• ?:, sizeof, ::, .
Operator overloading in Unary operators
• Unary operators
Pre-increment
operate on only one
operand.
– The increment
operator ++ and
decrement operator
-- are examples of
unary operators. Post-increment
Operator overloading in Binary operators
• Binary operators work on two operands
class Complex{ int main(){
public: Complex c1, c2;
int r, i; Complex c3 = c1+c2;
Complex operator + (const Complex& c) { //c3 = c1.operator+(c2);
Complex temp; return 0;
temp.r = r + c.r; }
temp.i = i + c.i;
return temp;
}
}
Operator overloading
• Two operators = and & are already overloaded by default in C++.
– For example, to copy objects of the same class, we can directly use the = operator i.e.
default copying. We do not need to create an operator function.
– &obj means address of obj→ & is overloaded for class, structure, union.
• We can overload &, but it is not a good practice.
• Operator overloading cannot change the precedence and associativity of
operators.
– Example:
• obj1 + ++obj2 – obj1 * obj2 / obj1;
• ((obj1 + (++obj2)) – obj1) * obj2 / obj1;
• There are 4 operators that cannot be overloaded in C++.
– :: (scope resolution operator)
– . (member selection) and .* (member selection through pointer to function)
– sizeof operator
– ?: (ternary operator)
Different approaches to Operator overloading
• We can perform operator overloading by implementing any of the
following types of functions.
– Member function (we have seen this so far)
• c3 = c1 + c2; → c3 = c1.operator + (c2);
• The operator overloading function may be a member function when a left operand is
an object of the class.
– Non-member function
• Complex operator + (const Complex &c1, const Complex &c2){…}
• When the left operand is different, the operator overloading function should be a
non-member function.
– Friend function
• We can make the operator overloading function a friend function if it needs to access
the private and protected class members.
Restrictions to Operator overloading
• The operators :: (scope resolution), . (member access), .* (member access
through pointer to member), and ?: (ternary conditional) cannot be overloaded.
• New operators (non-operators) such as **, <>, or &| cannot be created.
– Only existing operators can be overloaded.
• It is not possible to change the precedence, grouping, or number of operands of
operators.
• The overload of operator -> must either return a raw pointer, or return an object
(by reference or by value) for which operator -> is in turn overloaded.
– *ptr = &obj; → (*ptr).i <-> a.i <-> ptr -> i
– Whenever we overload this operator ->, it must return an address to some data member
of the class.
• The overloads of operators && and || lose short-circuit evaluation.
Function call operator
• When a user-defined class overloads the function call operator
i.e. (), it becomes a FunctionObject type.
– An object of such a type can be used in a function call like expression.