Analysis of constructor methods in Python (with examples)
The content of this article is about the analysis of construction methods in Python (with examples). It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.
In Python, you will see function names preceded and followed by double underscores, such as __init__(self). This type of writing has special meaning in Python. If an object uses one of these methods, that method will be executed under special circumstances, but such methods are rarely called directly.
If there is no need to be compatible with older versions of Python code, we should write all classes as new-style classes and use features such as the super function when writing code.
There are no "old-style" classes in Python 3.0, and there is no need to subclass Object or set the metaclass to type (starting line of code __metaclass__=type). That's because all All classes are implicitly subclasses of Object. If there is no explicit superclass, it will be subclassed directly; otherwise, it will be subclassed indirectly.
Constructor method in Python
The constructor method is different from other methods. When an object is created, the constructor method will be called immediately.
Rewrite general methods and special construction methods:
After understanding the concept of inheritance, we know that each class may have one or more superclasses, and subclasses inherit from the parent class. Inherit some behaviors of the parent class. Not only that, we can also override some super class methods to customize inheritance behavior.
class Bird: def __init__(self): self.hungry=True def eat(self): if self.hungry: print('我在吃') self.hungry=False else: print('我吃饱了,谢谢') sb=Bird() sb.eat() sb.eat()
Print result:
我在吃 我吃饱了,谢谢
It can be known from the code that after the bird is full, it will change its hunger state to Flase means that the bird is full. When the eat function is called, it will print that I am full. Thank you. This is through the use of the __init__ function in a class. Let’s look at the extended case. Eating is the basic characteristic of birds, and Bird can be regarded as the base class of birds. Now we write a singing bird, because we have already written a bird base class, and now we only need to inherit it. Our bird will not only sing but also learn the skill of eating by default.
class Bird: def __init__(self): self.hungry=True def eat(self): if self.hungry: print('ahhh') self.hungry=False else: print('no thanks') class SongBird(Bird): def __init__(self): self.sound='Squawk' def sing(self): print(self.sound) sb=SongBird() sb.sing() sb.eat() sb.eat()
Print results:
Traceback (most recent call last): Squawk File "F:/Python培训/博客园随笔专用/文件操作/文件读写.py", line 20, in <module> sb.eat() File "F:/Python培训/博客园随笔专用/文件操作/文件读写.py", line 5, in eat if self.hungry: AttributeError: 'SongBird' object has no attribute 'hungry'
Unfortunately, our birds can trigger The singing function, but when the eating function of the parent class is called, an exception is thrown. Looking at the eat function defined in the parent class, you need to set the hungry attribute to start the eat function. But what is puzzling is that we have inherited the base class Bird, and Bird also defines hungry, why does it not work? That's because the hungry attribute only takes effect when the parent class calls its own constructor. It can be seen that SingBird inherits all the functions of Bird, but does not trigger Bird's initialization function. Modify the following code
class Bird: def __init__(self): self.hungry=True def eat(self): if self.hungry: print('ahhh') self.hungry=False else: print('no thanks') class SongBird(Bird): def __init__(self): Bird.__init__(self) self.sound='Squawk' def sing(self): print(self.sound) sb=SongBird() sb.sing() sb.eat() sb.eat()
Output result:
Squawk ahhh no thanks
We can know from the code that we When SongBird initializes the class, Bird's initialization function is called. Therefore, Bird's constructor is triggered. Now our birds can not only sing but also have the eating behavior of the basic species.
Look at its execution process. While SongBird initializes itself, it passes itself as a parameter to its parent class, which means telling the parent class that when you created me, you had to give me innate skills (knowing how to feed myself). That is, the hungry attribute is set.
Using the Super function
The above method was written before 3.0. The super function will be used in the new class to solve the above problems.
class Bird: def __init__(self): self.hungry=True def eat(self): if self.hungry: print('ahhh') self.hungry=False else: print('no thanks') class SongBird(Bird): def __init__(self): super(SongBird, self).__init__() self.sound='Squawk' def sing(self): print(self.sound) sb=SongBird() sb.sing() sb.eat() sb.eat()
The current class and object are called as parameters, and any method of calling the object returned by the function is a method of calling the super class. Summary: The subclass and subclass object are passed explicitly and the constructor is called, but the constructor of the parent class is implicitly executed.
The above is the detailed content of Analysis of constructor methods in Python (with examples). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The speed of mobile XML to PDF depends on the following factors: the complexity of XML structure. Mobile hardware configuration conversion method (library, algorithm) code quality optimization methods (select efficient libraries, optimize algorithms, cache data, and utilize multi-threading). Overall, there is no absolute answer and it needs to be optimized according to the specific situation.

An application that converts XML directly to PDF cannot be found because they are two fundamentally different formats. XML is used to store data, while PDF is used to display documents. To complete the transformation, you can use programming languages and libraries such as Python and ReportLab to parse XML data and generate PDF documents.

It is impossible to complete XML to PDF conversion directly on your phone with a single application. It is necessary to use cloud services, which can be achieved through two steps: 1. Convert XML to PDF in the cloud, 2. Access or download the converted PDF file on the mobile phone.

To generate images through XML, you need to use graph libraries (such as Pillow and JFreeChart) as bridges to generate images based on metadata (size, color) in XML. The key to controlling the size of the image is to adjust the values of the <width> and <height> tags in XML. However, in practical applications, the complexity of XML structure, the fineness of graph drawing, the speed of image generation and memory consumption, and the selection of image formats all have an impact on the generated image size. Therefore, it is necessary to have a deep understanding of XML structure, proficient in the graphics library, and consider factors such as optimization algorithms and image format selection.

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.

XML can be converted to images by using an XSLT converter or image library. XSLT Converter: Use an XSLT processor and stylesheet to convert XML to images. Image Library: Use libraries such as PIL or ImageMagick to create images from XML data, such as drawing shapes and text.

Use most text editors to open XML files; if you need a more intuitive tree display, you can use an XML editor, such as Oxygen XML Editor or XMLSpy; if you process XML data in a program, you need to use a programming language (such as Python) and XML libraries (such as xml.etree.ElementTree) to parse.

To convert XML images, you need to determine the XML data structure first, then select a suitable graphical library (such as Python's matplotlib) and method, select a visualization strategy based on the data structure, consider the data volume and image format, perform batch processing or use efficient libraries, and finally save it as PNG, JPEG, or SVG according to the needs.
