330 likes | 474 Views
Overloading Operators. Operators. Operators are functions, but with a different kind of name – a symbol. Functions have parameters to which you pass arguments; operators have parameters to which you pass operands. Operands = Arguments. The name of a operator is “operator <symbol>”
E N D
Operators Operators are functions, but with a different kind of name – a symbol. Functions have parameters to which you pass arguments; operators have parameters to which you pass operands. Operands = Arguments. The name of a operator is “operator <symbol>” Operators are called differently from functions.
Operators Operators are functions, but with a different kind of name – a symbol. Functions have parameters to which you pass arguments; operators have parameters to which you pass operands. Operands = Arguments. The name of a operator is “operator <symbol>” Operators are called differently from functions. We say “operator overloading” because all operators are already defined – you cannot create new operators.
Operators • Operators are functions, but with a different kind of name – a symbol. • Functions have parameters to which you pass arguments; operators have parameters to which you pass operands. Operands = Arguments. • The name of a operator is “operator <symbol>” • Operators are called differently from functions. • We say “operator overloading” because all operators are already defined – you cannot create new operators. • An operator can be defined either as a member function of a class or a non-member function.
Operator Calls Example: var1 * var2 (a binary operator)
Operator Calls • Example: var1 * var2 (a binary operator) • var1 is the lhs operand, var2 is the rhs operand. • If operator * () is a non-member function, then var1 and var2 are arguments passed to fill two parameters. • If operator * () is a member function, then var1 is the calling object and var2 is passed to a parameter
Operator Calls • Example: ~var1 (a unary operator) • var1 is the only operand. • If operator ~ () is a non-member function, then var1 is the argument passed to fill a single parameter. • If operator ~ () is a member function, then var1 is the calling object.
Operators • insertion and extraction: >> and << • cout << var; • cin >> var;
Operators • insertion and extraction: >> and << • arithmetic: +, -, *, and / • var1 + var2 • var1 - var2 • var1 * var2 • var1 / var2
Operators • insertion and extraction: >> and << • arithmetic: +, -, *, and / • assignments: = • var1 = var2; • var1 = var2 + var3;
Operators • insertion and extraction: >> and << • arithmetic: +, -, *, and / • assignments: = • arithmetic assignments: +=, -=, *=, and /= • var1 += var2; • var1 -= var2; • var1 *= var2; • var1 /= var2;
Operators • insertion and extraction: >> and << • arithmetic: +, -, *, and / • assignments: = • arithmetic assignments: +=, -=, *=, and /= • brackets and parenthesis: [] and () • object[index_pos] = var; • object(var);
Operators insertion and extraction: >> and << arithmetic: +, -, *, and / assignments: = arithmetic assignments: +=, -=, *=, and /= brackets and parenthesis: [] and () and many others!
Operators insertion and extraction: >> and << arithmetic: +, -, *, and / assignments: = arithmetic assignments: +=, -=, *=, and /= brackets and parenthesis: [] and () and many others! FORBIDDEN OVERLOADS: :: . .* sizeof ?:
Additional Rules You cannot create new operators.
Additional Rules You cannot create new operators. If you overload an operator, at least one of the parameters must be a user-defined type.
Additional Rules You cannot create new operators. If you overload an operator, at least one of the parameters must be a user-defined type. You cannot change the arity of a operator.
Additional Rules You cannot create new operators. If you overload an operator, at least one of the parameters must be a user-defined type. You cannot change the arity of a operator. You cannot change the order of precedence of operators by overloading them.
Additional Rules You cannot create new operators. If you overload an operator, at least one of the parameters must be a user-defined type. You cannot change the arity of a operator. You cannot change the order of precedence of operators by overloading them. Certain operators must be overloaded as class members. They are = [] () ->
Additional Rules You cannot create new operators. If you overload an operator, at least one of the parameters must be a user-defined type. You cannot change the arity of a operator. You cannot change the order of precedence of operators by overloading them. Certain operators must be overloaded as class members. They are = [] () -> An overloaded operator cannot have default arguments.
Rules of Thumb Make your definitions of an overloaded operator make sense. As an example, you would not want to define ‘+’ for complex numbers as subtraction.
Rules of Thumb Make your definitions of an overloaded operator make sense. As an example, you would not want to define ‘+’ for complex numbers as subtraction. Define an operator overload as a member function if it modifies the calling object; as a nonmember function if it doesn’t.
Rules of Thumb Make your definitions of an overloaded operator make sense. As an example, you would not want to define ‘+’ for complex numbers as subtraction. Define an operator overload as a member function if it modifies the calling object; as a nonmember function if it doesn’t. Define symmetric operator pairs in terms of one another. As an example, define != using the == operator you already defined.
Recall //fraction.h ... class Fraction { ... • friend Fraction mult_fracs(const Fraction & lhs, const Fraction & rhs); • ... }; //fraction.cpp ... Fractionmult_fracs(const Fraction & lhs, const Fraction & rhs) { Fraction temp; temp.m_Numerator = lhs.m_Numerator * rhs.m_Numerator; temp.m_Denominator = lhs.m_Denominator * rhs.m_Denominator; return temp; }
Revised! //fraction.h ... class Fraction { ... • friend Fraction operator* (const Fraction & lhs, const Fraction & rhs); • ... }; //fraction.cpp ... • Fractionoperator* (const Fraction & lhs, const Fraction & rhs) { Fraction result(lhs); return (result*=rhs); }
Revised! //fraction.h ... class Fraction { ... • friend Fraction operator* (const Fraction & lhs, const Fraction & rhs); • ... }; //fraction.cpp ... • Fractionoperator* (const Fraction & lhs, const Fraction & rhs) { Fraction result(lhs); return (result*=rhs); } needs to be defined
Revised! //fraction.h ... class Fraction { ... • friend Fraction operator* (const Fraction & lhs, const Fraction & rhs); • Fraction& operator*= (const Fraction & rhs); • ... }; //fraction.cpp ... • Fraction& Fraction::operator*= (const Fraction & rhs) { • m_Numerator*=rhs.m_Numerator; • m_Denominator*=rhs.m_Denominator; • return (*this); • }
*this int int pointer 5 x
*this int int pointer 5 x x refers to the pointer
*this int int pointer 5 x *x refers to the int being pointed at
*this Fraction pointer this this refers to the pointer that is keeping track of your Fraction object’s place in memory – pointing to the calling objectof this function Fraction • Fraction& Fraction::operator*= (const Fraction & rhs) • { • m_Numerator*=rhs.m_Numerator; • m_Denominator*=rhs.m_Denominator; • return (*this); • }
*this Fraction pointer this *this refers to the fraction object currently executing your call to *= the calling object Fraction • Fraction& Fraction::operator*= (const Fraction & rhs) • { • m_Numerator*=rhs.m_Numerator; • m_Denominator*=rhs.m_Denominator; • return (*this); • }