


A brief introduction to the three methods __init__, __new__ and __call__ in python
This article mainly introduces you to the relevant information about the __init__, __new__ and __call__ methods in python. The article introduces it in detail through the example code, which has certain reference and learning value for everyone. Friends who need it can For reference study, let’s follow the editor and take a look.
Preface
This article mainly introduces to you the relevant content about the __init__, __new__ and __call__ methods in python, and share it for your reference. Let’s learn for reference. Not much to say below, let’s take a look at the detailed introduction:
Everything has a process from creation, use, to death. In the object-oriented programming model of programming language, Objects also have a similar fate: creation, initialization, use, and garbage collection. Different stages are executed by different methods (roles).
When defining a class, the most commonly used method is the __init__ method, while __new__ and __call__ are used less frequently. This article attempts to help you understand the correct use and application scenarios of these three methods. Explain them separately.
I won’t discuss too much about Python’s new-style classes and old-style classes in this article, because old-style classes are a concept in Python 2. Now almost no one will use old-style classes anymore. New-style classes must explicitly inherit object. In Python3, there are only new-style classes, which inherit object by default and do not need to be specified explicitly. The codes in this article are all discussed based on Python3.
__init__ method
__init__ method is responsible for the initialization of the object. Before the system executes this method, the object already exists, otherwise What to initialize? Let’s look at the example first:
# class A(object): python2 必须显示地继承object class A: def __init__(self): print("__init__ ") super(A, self).__init__() def __new__(cls): print("__new__ ") return super(A, cls).__new__(cls) def __call__(self): # 可以定义任意参数 print('__call__ ') A()
Output
##
__new__ __init__
def __init__(self): print("__init__ ") print(self) super(A, self).__init__() def __new__(cls): print("__new__ ") self = super(A, cls).__new__(cls) print(self) return self
__new__ <__main__.A object at 0x1007a95f8> __init__ <__main__.A object at 0x1007a95f8>
def __init__(self, a, b): self.a = a self.b = b super(A, self).__init__()
class B: def __init__(self, *args, **kwargs): print("init", args, kwargs) def __new__(cls, *args, **kwargs): print("new", args, kwargs) return super().__new__(cls) B(1, 2, 3) # 输出 new (1, 2, 3) {} init (1, 2, 3) {}
__new__ Method
Generally we will not override this method unless you know for sure How to do it, when will you care about it? It is used as a constructor to create objects. It is a factory function dedicated to producing instance objects. One of the famous design patterns, the singleton pattern, can be implemented through this method. You may use it when writing framework-level code yourself. We can also find its application scenarios from open source code, such as the micro Web framework Bootle.class BaseController(object): _singleton = None def __new__(cls, *a, **k): if not cls._singleton: cls._singleton = object.__new__(cls, *a, **k) return cls._singleton
__call__ method
About the __call__ method, no Not to mention a concept first, that is, callable objects. Our usual custom functions, built-in functions and classes are all callable objects, but anything that can apply a pair of brackets () to an object can be called It is a callable object. To determine whether the object is a callable object, you can use the function callableIf the __call__ method is implemented in the class, then the instance object will also become a callable object. Let’s go back to the beginning. That example:a = A() print(callable(a)) # True
a() # __call__
很神奇不是,实例对象也可以像函数一样作为可调用对象来用,那么,这个特点在什么场景用得上呢?这个要结合类的特性来说,类可以记录数据(属性),而函数不行(闭包某种意义上也可行),利用这种特性可以实现基于类的装饰器,在类里面记录状态,比如,下面这个例子用于记录函数被调用的次数:
class Counter: def __init__(self, func): self.func = func self.count = 0 def __call__(self, *args, **kwargs): self.count += 1 return self.func(*args, **kwargs) @Counter def foo(): pass for i in range(10): foo() print(foo.count) # 10
在 Bottle 中也有 call 方法 的使用案例,另外,stackoverflow 也有一些关于 call 的实践例子,推荐看看,如果你的项目中,需要更加抽象化、框架代码,那么这些高级特性往往能发挥出它作用。
总结
The above is the detailed content of A brief introduction to the three methods __init__, __new__ and __call__ in python. 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

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.

There is no simple and direct free XML to PDF tool on mobile. The required data visualization process involves complex data understanding and rendering, and most of the so-called "free" tools on the market have poor experience. It is recommended to use computer-side tools or use cloud services, or develop apps yourself to obtain more reliable conversion effects.

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.

Modifying XML content requires programming, because it requires accurate finding of the target nodes to add, delete, modify and check. The programming language has corresponding libraries to process XML and provides APIs to perform safe, efficient and controllable operations like operating databases.

XML formatting tools can type code according to rules to improve readability and understanding. When selecting a tool, pay attention to customization capabilities, handling of special circumstances, performance and ease of use. Commonly used tool types include online tools, IDE plug-ins, and command-line tools.

XML beautification is essentially improving its readability, including reasonable indentation, line breaks and tag organization. The principle is to traverse the XML tree, add indentation according to the level, and handle empty tags and tags containing text. Python's xml.etree.ElementTree library provides a convenient pretty_xml() function that can implement the above beautification process.

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.

It is not easy to convert XML to PDF directly on your phone, but it can be achieved with the help of cloud services. It is recommended to use a lightweight mobile app to upload XML files and receive generated PDFs, and convert them with cloud APIs. Cloud APIs use serverless computing services, and choosing the right platform is crucial. Complexity, error handling, security, and optimization strategies need to be considered when handling XML parsing and PDF generation. The entire process requires the front-end app and the back-end API to work together, and it requires some understanding of a variety of technologies.
