What do @classmethod and @staticmethod mean in Python, and how are they different? When should I use them, why should I use them, and how should I use them?
As far as I understand, @classmethod tells a class that it’s a method which should be inherited into subclasses, or… something. However, what’s the point of that? Why not just define the class method without adding @classmethod or @staticmethod or any @ definitions?
Though
classmethodandstaticmethodare quite similar, there’s a slight difference in usage for both entities:classmethodmust have a reference to a class object as the first parameter, whereasstaticmethodcan have no parameters at all.Example
Explanation
Let’s assume an example of a class, dealing with date information (this will be our boilerplate):
This class obviously could be used to store information about certain dates (without timezone information; let’s assume all dates are presented in UTC).
Here we have
__init__, a typical initializer of Python class instances, which receives arguments as a typical instance method, having the first non-optional argument (self) that holds a reference to a newly created instance.Class Method
We have some tasks that can be nicely done using
classmethods.Let’s assume that we want to create a lot of
Dateclass instances having date information coming from an outer source encoded as a string with format ‘dd-mm-yyyy’. Suppose we have to do this in different places in the source code of our project.So what we must do here is:
Dateby passing those values to the initialization call.This will look like:
For this purpose, C++ can implement such a feature with overloading, but Python lacks this overloading. Instead, we can use
classmethod. Let’s create another constructor.Let’s look more carefully at the above implementation, and review what advantages we have here:
clsis the class itself, not an instance of the class. It’s pretty cool because if we inherit ourDateclass, all children will havefrom_stringdefined also.Static method
What about
staticmethod? It’s pretty similar toclassmethodbut doesn’t take any obligatory parameters (like a class method or instance method does).Let’s look at the next use case.
We have a date string that we want to validate somehow. This task is also logically bound to the
Dateclass we’ve used so far, but doesn’t require instantiation of it.Here is where
staticmethodcan be useful. Let’s look at the next piece of code:So, as we can see from usage of
staticmethod, we don’t have any access to what the class is—it’s basically just a function, called syntactically like a method, but without access to the object and its internals (fields and other methods), whichclassmethoddoes have.