Python __new__()方法详解
__new__() 是一种负责创建类实例的静态方法,它无需使用 staticmethod 装饰器修饰,且该方法会优先 __init__() 初始化方法被调用。
一般情况下,覆写 __new__() 的实现将会使用合适的参数调用其超类的 super().__new__(),并在返回之前修改实例。例如:
- class demoClass:
- instances_created = 0
- def __new__(cls,*args,**kwargs):
- print("__new__():",cls,args,kwargs)
- instance = super().__new__(cls)
- instance.number = cls.instances_created
- cls.instances_created += 1
- return instance
- def __init__(self,attribute):
- print("__init__():",self,attribute)
- self.attribute = attribute
- test1 = demoClass("abc")
- test2 = demoClass("xyz")
- print(test1.number,test1.instances_created)
- print(test2.number,test2.instances_created)
输出结果为:
__new__(): <class '__main__.demoClass'> ('abc',) {}
__init__(): <__main__.demoClass object at 0x0000026FC0DF8080> abc
__new__(): <class '__main__.demoClass'> ('xyz',) {}
__init__(): <__main__.demoClass object at 0x0000026FC0DED358> xyz
0 2
1 2
__new__() 通常会返回该类的一个实例,但有时也可能会返回其他类的实例,如果发生了这种情况,则会跳过对 __init__() 方法的调用。而在某些情况下(比如需要修改不可变类实例(Python 的某些内置类型)的创建行为),利用这一点会事半功倍。比如:
- class nonZero(int):
- def __new__(cls,value):
- return super().__new__(cls,value) if value != 0 else None
- def __init__(self,skipped_value):
- #此例中会跳过此方法
- print("__init__()")
- super().__init__()
- print(type(nonZero(-12)))
- print(type(nonZero(0)))
运行结果为:
__init__()
<class '__main__.nonZero'>
<class 'NoneType'>
那么,什么情况下使用 __new__() 呢?答案很简单,在 __init__() 不够用的时候。
例如,前面例子中对 Python 不可变的内置类型(如 int、str、float 等)进行了子类化,这是因为一旦创建了这样不可变的对象实例,就无法在 __init__() 方法中对其进行修改。
有些读者可能会认为,__new__() 对执行重要的对象初始化很有用,如果用户忘记使用 super(),可能会漏掉这一初始化。虽然这听上去很合理,但有一个主要的缺点,即如果使用这样的方法,那么即便初始化过程已经是预期的行为,程序员明确跳过初始化步骤也会变得更加困难。不仅如此,它还破坏了“__init__() 中执行所有初始化工作”的潜规则。
注意,由于 __new__() 不限于返回同一个类的实例,所以很容易被滥用,不负责任地使用这种方法可能会对代码有害,所以要谨慎使用。一般来说,对于特定问题,最好搜索其他可用的解决方案,最好不要影响对象的创建过程,使其违背程序员的预期。比如说,前面提到的覆写不可变类型初始化的例子,完全可以用工厂方法(一种设计模式)来替代。
Python中大量使用 __new__() 方法且合理的,就是 MetaClass 元类。有关元类的介绍
相关文章:
Python __new__()方法详解
__new__() 是一种负责创建类实例的静态方法,它无需使用 staticmethod 装饰器修饰,且该方法会优先 __init__() 初始化方法被调用。 一般情况下,覆写 __new__() 的实现将会使用合适的参数调用其超类的 super().__new__(),并在返回之…...
虹科 | 解决方案 | 汽车示波器 索赔管理方案
索赔管理 Pico汽车示波器应用于主机厂/供应商与服务店/4S店的协作,实现产品索赔工作的高效管理;同时收集的故障波形数据,便于日后的产品优化和改进 故障记录 在索赔申请过程中,Pico汽车示波器的数据记录功能可以用于捕捉故障时的…...
详解Jmeter中的BeanShell脚本
BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法,所以它和java是可以无缝衔接的,学了Java的一些基本语法后,就可以来在Jmeter中写写BeanShell脚本了 在利用jmeter进行接口测试或者性能测试的时候,…...
前端和后端 优化
1.前端资源优化 1.1 html结构优化 保证简洁、清晰的html结构,减少或避免多余的html标签 使用HTML5的web语义化标签,结构清晰且利于seo css文件在head中引入,js文件放在body底部引入,这样做可以防止阻塞。另外如果有需要提前加载的…...
C++编译与运行:其二、编译期和运行期的区别
C的编译分为四步,最终生成一个可执行文件。 C的运行,就是将可执行文件交给操作系统,按照机器码逐步执行,运行功能。 先看一个非常非常有趣的例子: class Father{ public:virtual void f(){cout<<"I am fat…...
汽车电子专有名词与相应技术
1.EEA (Electronic & Electrical Architecture 电子电气架构) EEA在宏观上概括为物理架构与逻辑架构的结合,微观上通过众多电子元器件的协同配合,或集成式或分布式的系统级电子电气架构,具体详见专栏 新能源汽车电…...
idea 没加载 provided的包
目录 前言解决方案 前言 我的版本是IntelliJ IDEA 2022.1.4 (Community Edition),本地调试不知道为什么不加载provided的包。后来找到这篇文章https://youtrack.jetbrains.com/issue/IDEA-107048才知道这是个bug。不知道其他版本会不会出现这种问题。 解决方案 我…...
Hover:借贷新势力崛起,在经验与创新中找寻平衡
复苏中的Cosmos 如果让我选择一个最我感到可惜的区块链项目,我会选择Cosmos。 Cosmos最早提出并推动万链互联的概念,希望打通不同链之间的孤岛,彼时和另一个天王项目Polkadot号称跨链双雄。其跨链技术允许不同的区块链网络互相通信…...
软件设计原则-依赖倒置原则讲解以及代码示例
依赖倒置原则 一,介绍 1.前言 依赖倒置原则(Dependency Inversion Principle,DIP)是面向对象设计中的一个重要原则,由Robert C. Martin提出。 依赖倒置原则的核心思想是:高层模块不应该依赖于低层模块&…...
Linux--进程替换
1.什么是进程替换 在fork函数之后,父子进程各自执行代码的一部分,但是如果子进程想要执行一份全新的程序呢? 通过进程替换来完成,进程替换就是父子进程代码发生写时拷贝,子进程执行自己的功能。 程序替换就是通过特定的…...
【计算机网络】TCP协议
文章目录 1. TCP报文的结构2. TCP的发送缓冲区和接收缓冲区3. 确保可靠性序列号和确认序列号确认应答超时重传连接管理1️⃣三次握手建立连接2️⃣四次挥手断开连接 4. 提高性能流量控制滑动窗口拥塞控制延迟应答捎带应答 5. 面向字节流6. TCP/UDP对比 概念:TCP&…...
机器学习数据集:Kaggle
什么是Kaggle? Kaggle成立于2010年,是一个进行数据发掘和预测竞赛的在线平台。从公司的角度来讲,可以提供一些数据,进而提出一个实际需要解决的问题;从参赛者的角度来讲,他们将组队参与项目,针…...
软考 系统架构设计师系列知识点之设计模式(4)
接前一篇文章:软考 系统架构设计师系列知识点之设计模式(3) 所属章节: 老版(第一版)教材 第7章. 设计模式 第2节. 设计模式实例 3. 行为型模式 行为型模式可以影响一个系统的状态和行为流。通过优化状态…...
PyCharm 安装 cx_Oracle 失败
我在PyCharm的终端用 pip安装cx_Oracle失败,报错情况如下: ERROR: Could not build wheels for cx_Oracle, which is required to install pyproject.toml-based projects 出错原因: python 的版本太高了,我的是3.11版本的&…...
解决Windows出现找不到mfcm90u.dll无法打开软件程序的方法
今天,我非常荣幸能够在这里与大家分享关于mfc90u.dll丢失的5种解决方法。在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失。那么,mfc90u.dll究竟是什么文件呢?接下来,…...
如何设计线程安全的 HashMap?
如何设计线程安全的 HashMap? HashMap 线程不安全的体现: 多线程下扩容死循环:JDK1.7中的 HashMap 使用头插法插入元素,在多线程的环境下,扩容的时候有可能导致环形链表的出现,形成死循环。因此,JDK1.8使…...
rpc汇总
1、什么是rpc rpc的应用,有哪些 Google 开源了 gRPC, Facebook 开源了 Thrift, Twitter 开源了 Finagle, 百度开源了bRPC, 腾讯开源了 Tars, 阿里开源了 Dubbo 和 HSF, 新浪开源了 Motan 等 gr…...
OpenCV学习(五)——图像基本操作(访问图像像素值、图像属性、感兴趣区域ROI和图像边框)
图像基本操作 5. 图像基本操作5.1 访问像素值并修改5.2 访问图像属性5.2 图像感兴趣区域ROI5.3 拆分和合并图像通道5.4 为图像设置边框(填充) 5. 图像基本操作 访问像素值并修改访问图像属性设置感兴趣区域(ROI)分割和合并图像 …...
指针仪表读数YOLOV8NANO
指针仪表读数YOLOV8 NANO 采用YOLOV8 NANO训练,标记,然后判断角度,得出角度,可以通过角度,换算成数据...
10000字!图解机器学习特征工程
文章目录 引言特征工程1.特征类型1.1 结构化 vs 非结构化数据1.2 定量 vs 定性数据 2.数据清洗2.1 数据对齐2.2 缺失值处理 原文链接:https://www.showmeai.tech/article-detail/208 作者:showmeAI 引言 上图为大家熟悉的机器学习建模流程图,…...
3分钟解锁Steam游戏离线自由:SteamAutoCrack终极使用指南
3分钟解锁Steam游戏离线自由:SteamAutoCrack终极使用指南 【免费下载链接】Steam-auto-crack Steam Game Automatic Cracker 项目地址: https://gitcode.com/gh_mirrors/st/Steam-auto-crack 还在为Steam游戏必须联网验证而烦恼吗?当网络不稳定或…...
如何用猫抓构建智能命名系统:5个提升文件管理效率的技巧
如何用猫抓构建智能命名系统:5个提升文件管理效率的技巧 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 在数字资源爆炸的时代…...
Granite TimeSeries FlowState R1多步预测效果深度解析:不确定性估计与置信区间可视化
Granite TimeSeries FlowState R1多步预测效果深度解析:不确定性估计与置信区间可视化 1. 引言 在金融交易、能源负荷预测或者供应链管理这些领域,做预测从来都不是一件轻松的事。我们常常会遇到这样的困境:模型告诉你明天股价会涨…...
从零玩转GD32单片机USART:485总线通信实战与源码解析
1. 初识GD32单片机与USART通信 第一次接触GD32单片机时,我被它强大的外设功能所吸引。作为国产MCU的优秀代表,GD32在性能上完全不输国际大厂产品,而价格却亲民得多。记得当时为了调试一个简单的串口通信功能,我整整折腾了两天&am…...
LingBot-Depth开源大模型教程:贡献模型权重至Hugging Face流程指南
LingBot-Depth开源大模型教程:贡献模型权重至Hugging Face流程指南 1. 项目概述与价值 LingBot-Depth是一个基于深度掩码建模的空间感知模型,专门用于将不完整的深度传感器数据转换为高质量的度量级3D测量。这个开源项目在计算机视觉和3D感知领域具有重…...
快速上手:实时口罩检测-通用模型,从安装到检测只需10分钟
快速上手:实时口罩检测-通用模型,从安装到检测只需10分钟 1. 引言:为什么选择这个口罩检测模型 在公共场所管理、智能门禁系统或健康监测应用中,准确快速地检测人员是否佩戴口罩是一个常见需求。传统方案往往需要复杂的部署流程…...
SecGPT-14B保姆级教程:开源网络安全大模型GPU高效部署全流程
SecGPT-14B保姆级教程:开源网络安全大模型GPU高效部署全流程 1. 开篇:为什么你需要一个“懂安全”的AI助手? 想象一下,你正在分析一个复杂的网络攻击日志,面对海量的告警和模糊的线索,感觉像在大海里捞针…...
快速部署Qwen3-ASR-1.7B:实现多语言语音转文字功能实战教程
快速部署Qwen3-ASR-1.7B:实现多语言语音转文字功能实战教程 1. 引言:语音识别技术的新选择 语音转文字技术正在改变我们处理音频内容的方式。Qwen3-ASR-1.7B作为阿里通义千问推出的中等规模语音识别模型,凭借17亿参数的平衡设计,…...
高通Modem NV配置实战:从开机优化到网络兼容性调校
1. 高通Modem NV配置入门指南 第一次接触高通Modem NV配置时,我也被各种专业术语和参数搞得晕头转向。经过几个项目的实战,我发现这其实就像给手机做"微整形手术"——通过调整底层参数来优化设备性能。NV(Non-Volatile)配置是高通平台特有的持…...
安卓开发工程师技术指南与面试准备
引言 安卓开发工程师在现代移动应用生态中扮演着核心角色,负责设计、开发和维护高性能的Android客户端软件。随着智能手机的普及和移动互联网的快速发展,Android平台占据了全球移动操作系统市场的绝大部分份额。据StatCounter数据,Android在全球移动操作系统中的市场份额超…...
