In Python, when a subclass defines a function that already exists in its superclass in order to add some other functionality in its own way, the function in the subclass is said to be an extended method and the mechanism is known as extending. It is a way by which Python shows Polymorphism. This is similar to overriding in Java and virtual methods in C++. A call from the instance of the subclass executes the subclass’s version of the function. To call superclass’s version super()
method is used.
Why Extend a Function?
The goal of extending a class method in Python can be achieved by Inheritance. One of the major advantages provided by extending a method is that it makes the code reusable. Further, multiple subclasses can share the same code and are even allowed to update it as per the requirement.
We’ll deal with both cases here
CASE 1: without extending a class method
# definition of superclass "Triangles" class Triangles( object ):
count = 0
# Calling Constructor
def __init__( self , name, s1, s2, s3):
self .name = name
self .s1 = s1
self .s2 = s2
self .s3 = s3
Triangles.count + = 1
def setName( self , name):
self .name = name
def setdim( self , s1, s2, s3):
self .s1 = s1
self .s2 = s2
self .s3 = s3
def getcount( self ):
return Triangles.count
def __str__( self ):
return 'Name: ' + self .name + '\nDimensions: ' + str ( self .s1) + ',' + str ( self .s2) + ',' + str ( self .s3)
# describing a subclass # inherits from Triangles class Peri(Triangles):
# function to calculate the area
def calculate( self ):
self .pm = 0
self .pm = self .s1 + self .s2 + self .s3
# function to display just the area
# because it is not extended
def display( self ):
return self .pm
def main():
# instance of the subclass
p = Peri( 'PQR' , 2 , 3 , 4 )
# call to calculate()
p.calculate()
# explicit call to __str__()
print (p.__str__())
# call to display()
print (p.display())
main() |
Output:
Name: PQR Dimensions: 2, 3, 4 9
CASE 2: extending a class method
# definition of superclass "Triangles" class Triangles( object ):
count = 0
def __init__( self , name, s1, s2, s3):
self .name = name
self .s1 = s1
self .s2 = s2
self .s3 = s3
Triangles.count + = 1
def setName( self , name):
self .name = name
def setdim( self , s1, s2, s3):
self .s1 = s1
self .s2 = s2
self .s3 = s3
def getcount( self ):
return Triangles.count
# superclass's version of display()
def display( self ):
return 'Name: ' + self .name + '\nDimensions: ' + str ( self .s1) + ', ' + str ( self .s2) + ', ' + str ( self .s3)
# definition of the subclass # inherits from "Triangles" class Peri(Triangles):
def calculate( self ):
self .pm = 0
self .pm = self .s1 + self .s2 + self .s3
# extended method
def display( self ):
# calls display() of superclass
print ( super (Peri, self ).display())
# adding its own properties
return self .pm
def main():
# instance of the subclass
p = Peri( 'PQR' , 2 , 3 , 4 )
# call to calculate
p.calculate()
# one call is enough
print (p.display())
main() |
Output:
Name: PQR Dimensions: 2, 3, 4 9
The output produced in both cases is the same, the only difference being that the second case makes it easier for other subclasses to inherit the methods and “extend” them as required which as mentioned increases code reusability.