Static variables(also known as class variables) are shared among all instances of a class.
They are typically used to store information related to the class as a whole, rather than information related to a specific instance of the class.
Static variables are accessible from the class itself without necessarily having to create an instance of the class. They are initialized when the class is first loaded, and do not need to be explicitly initialized in the constructor.
Conventionally, static variables are declared at the top of the class before any other methods or fields. This makes them easily distinguishable from other variables.
Example of a static variable
Consider if we want to create a class that represents a citizen of a particular country, say India. Each objects of such a class can share the variable country. As shown below.
class Person:
country = "India" #This is a static variable
nationality = "Indian" #this too
def __init__(self, name):
self.name = name
#access class variable from the class itself
print(Person.country)
#Access class variables from class instance.
a = Person("Sanjay")
print(a.name)
print(a.nationality)
As shown above, to access static variables from outside the class, we use the class itself or an object of the class.
Accessing static variables within the class
We can also access the variables within the class at definition. However, how the variable behaves depends largely on where it is being accessed from.
If we access a static variable from an instance method, any modifications done will only be relevant to the object doing the modification.
class Person:
country = "India" #This is a static variable
nationality = "Indian"
def __init__(self, name):
self.name = name
#define an instance method
def change_nationality(self, new_country, new_nationality):
"""This method will only change static variables at instance level and not at the class level"""
self.country = new_country
self.nationality = new_nationality
a = Person("Rahul")
a.change_nationality("Japan", "Japanese") #This modifies the country and nationality for this object only
print(a.country)
print(a.nationality)
#The static variables at class level remains unchanged
print(Person.country)
print(Person.nationality)
On the other hand, if static variables are modified from a class method, the change takes effect in the whole class.
Consider the following example:
class Person:
country = "India" #This is a static variable
nationality = "Indian"
def __init__(self, name):
self.name = name
#define a class method
@classmethod
def change_nationality(cls, new_country, new_nationality):
"""This method will make changes at class level."""
self.country = new_country
self.nationality = new_nationality
a = Person("Rahul")
print(a.country)
a.change_nationality("Japan", "Japanese") #This modifies the country and nationality for the whole class.
#The static variables at class level are now changed
print(Person.country)
print(Person.nationality)
b = Person("Kumar")#This object will have Japan as the country and Japanese as nationality
print(b.country)
print(b.nationality)
Static variables should be used with caution, since they are global state that is shared across all instances of a class. As you have seen above, they behaves differently depending on where they are being accessed/modified.
Understanding how the various methods work can be crucial in avoiding the pitfall of having static variables modified in a way that can lead to unexpected results. Visit the article on Instance, Class and Static methods to see how each of these methods works.