当前位置: 首页 > news >正文

Python类的力量:第五篇:魔法方法与协议——让类拥有Python的“超能力”

文章目录

        • 前言:从“普通对象”到“Python原生公民”的进化之路
      • 一、魔法方法:赋予对象“超能力”的基因
        • 1. 构造与析构:对象生命周期的“魔法开关”
        • 2. 字符串表示:对象的“自我介绍”
        • 3. 运算符重载:让对象支持“数学魔法”
        • 4. 属性访问控制:动态拦截属性操作
      • 二、协议:融入Python生态的“通用语言”
        • 1. 可调用对象协议:对象变身“函数”
        • 2. 上下文管理协议:资源的“自动管家”
        • 3. 序列协议:让对象支持索引与切片
        • 4. 描述符协议:属性的“智能代理”
      • 三、行业案例解析:魔法方法的实战应用
        • 1. 金融计算:自定义货币类型
        • 2. 数据分析:自定义数据集对象
        • 3. 游戏开发:角色状态的动态管理
      • 四、进阶技巧:魔法方法的深度优化
        • 1. 运算符重载的高级模式:自定义比较逻辑
        • 2. 协议的显式约束:使用抽象基类(ABC)
        • 3. 性能优化:缓存与惰性计算
      • 五、总结:从“代码工具”到“生态公民”的思维跃迁


前言:从“普通对象”到“Python原生公民”的进化之路

在Python中,类不仅是数据与行为的封装体,更是可以深度融入语言生态的“一等公民”。通过实现魔法方法(Magic Methods)和协议(Protocols),自定义类可以像内置类型(如listdict)一样支持运算符操作、迭代、上下文管理等特性,甚至创造出全新的编程范式。本文将通过具体案例,解析如何通过魔法方法让类拥有Python的“超能力”,实现代码的自然交互与高效复用。

一、魔法方法:赋予对象“超能力”的基因

1. 构造与析构:对象生命周期的“魔法开关”
  • __init__:初始化对象属性,替代传统的构造函数:
    class User:def __init__(self, name: str, age: int):self.name = nameself.age = age
    
  • __del__:对象销毁前释放资源(如关闭文件或数据库连接):
    class Database:def __del__(self):self.connection.close()
    

核心优势

  • 自动资源管理__del__确保对象不再使用时自动清理
  • 统一初始化逻辑__init__集中处理对象状态设置
2. 字符串表示:对象的“自我介绍”
  • __str__:用户友好的字符串表示(print()调用):
    class Point:def __init__(self, x: float, y: float):self.x = xself.y = ydef __str__(self):return f"Point({self.x}, {self.y})"
    
  • __repr__:开发者友好的字符串表示(交互式解释器默认输出):
    def __repr__(self):return f"Point({self.x!r}, {self.y!r})"  # 使用!r确保数值类型的原始表示
    

最佳实践

  • __repr__应可复现对象eval(repr(obj)) == obj
  • __str__侧重可读性__repr__侧重精确性
3. 运算符重载:让对象支持“数学魔法”

通过实现__add____sub__等方法,自定义类可以支持运算符操作:

class Vector:def __init__(self, x: float, y: float):self.x = xself.y = ydef __add__(self, other: 'Vector') -> 'Vector':return Vector(self.x + other.x, self.y + other.y)def __sub__(self, other: 'Vector') -> 'Vector':return Vector(self.x - other.x, self.y - other.y)def __mul__(self, scalar: float) -> 'Vector':return Vector(self.x * scalar, self.y * scalar)# 使用示例
v1 = Vector(1, 2)
v2 = Vector(3, 4)
result = v1 + v2  # 自动调用__add__
print(result.x, result.y)  # 输出:4 6

扩展场景

  • 反向运算符__radd__处理左操作数为内置类型的情况
  • 复合赋值运算符__iadd__实现v1 += v2的原地修改
4. 属性访问控制:动态拦截属性操作
  • __getattr__:访问不存在的属性时触发:
    class LazyLoader:def __getattr__(self, name: str):# 动态加载模块module = __import__(name)setattr(self, name, module)return moduleloader = LazyLoader()
    loader.math.sqrt(4)  # 动态加载math模块
    
  • __setattr__:设置属性时拦截并验证:
    class User:def __setattr__(self, name: str, value):if name == 'age' and not isinstance(value, int):raise TypeError("Age must be an integer")super().__setattr__(name, value)
    

关键应用

  • 属性验证:确保属性值符合业务规则
  • 延迟加载:按需加载资源,提升性能

二、协议:融入Python生态的“通用语言”

1. 可调用对象协议:对象变身“函数”

通过__call__方法,对象可以像函数一样被调用:

class Counter:def __init__(self):self.count = 0def __call__(self):self.count += 1return self.countcounter = Counter()
print(counter())  # 输出:1
print(counter())  # 输出:2

典型场景

  • 装饰器:通过__call__实现函数增强
  • 策略模式:不同对象实现相同__call__接口
2. 上下文管理协议:资源的“自动管家”

通过__enter____exit__方法,对象支持with语句:

class FileHandler:def __init__(self, filename: str, mode: str):self.filename = filenameself.mode = modeself.file = Nonedef __enter__(self):self.file = open(self.filename, self.mode)return self.file  # 返回值绑定到as子句def __exit__(self, exc_type, exc_val, exc_tb):if self.file:self.file.close()# 使用示例
with FileHandler("data.txt", "w") as f:f.write("Hello, World!")

核心优势

  • 异常安全:无论代码块是否抛出异常,__exit__都会执行
  • 资源自动释放:避免手动调用close()导致的资源泄漏
3. 序列协议:让对象支持索引与切片

通过__len____getitem__方法,对象可以像列表一样操作:

class MyList:def __init__(self, *elements):self.elements = list(elements)def __len__(self):return len(self.elements)def __getitem__(self, index):return self.elements[index]# 使用示例
my_list = MyList(1, 2, 3, 4)
print(len(my_list))       # 输出:4
print(my_list[1:3])       # 输出:[2, 3]

进阶实现

  • 切片处理:在__getitem__中判断index是否为slice类型
  • 动态扩容:在__setitem__中实现动态数组逻辑
4. 描述符协议:属性的“智能代理”

通过__get____set____delete__方法,实现属性的自定义访问逻辑:

class ValidatedInteger:def __init__(self, min_value: int, max_value: int):self.min_value = min_valueself.max_value = max_valuedef __get__(self, instance, owner):return instance.__dict__[self.name]def __set__(self, instance, value):if not isinstance(value, int) or not (self.min_value <= value <= self.max_value):raise ValueError(f"Value must be an integer between {self.min_value} and {self.max_value}")instance.__dict__[self.name] = valuedef __set_name__(self, owner, name):self.name = name# 使用示例
class User:age = ValidatedInteger(0, 150)  # 年龄必须在0-150之间user = User()
user.age = 25  # 正常赋值
user.age = 200 # 抛出ValueError

核心价值

  • 属性复用:验证逻辑可在多个类中共享
  • 解耦业务规则:属性验证与类逻辑分离

三、行业案例解析:魔法方法的实战应用

1. 金融计算:自定义货币类型

通过运算符重载和上下文管理,实现货币的精确计算:

class Currency:def __init__(self, amount: float, currency_code: str):self.amount = round(amount, 2)  # 精确到分self.currency_code = currency_codedef __add__(self, other: 'Currency') -> 'Currency':if self.currency_code != other.currency_code:raise ValueError("Currencies must be the same")return Currency(self.amount + other.amount, self.currency_code)def __enter__(self):print("开启货币计算上下文")return selfdef __exit__(self, exc_type, exc_val, exc_tb):print("关闭货币计算上下文")# 使用示例
with Currency(100.0, "USD") as usd:total = usd + Currency(50.0, "USD")print(total.amount)  # 输出:150.00
2. 数据分析:自定义数据集对象

通过序列协议和运算符重载,实现数据集的高效操作:

class DataSet:def __init__(self, data: list[float]):self.data = datadef __len__(self):return len(self.data)def __getitem__(self, index):return self.data[index]def __add__(self, other: 'DataSet') -> 'DataSet':if len(self) != len(other):raise ValueError("Datasets must have the same length")return DataSet([a + b for a, b in zip(self.data, other.data)])# 使用示例
ds1 = DataSet([1, 2, 3])
ds2 = DataSet([4, 5, 6])
result = ds1 + ds2  # 自动调用__add__
print(result.data)   # 输出:[5, 7, 9]
3. 游戏开发:角色状态的动态管理

通过描述符协议和属性访问控制,实现角色状态的自动验证:

class Health:def __get__(self, instance, owner):return instance._healthdef __set__(self, instance, value):if value < 0:raise ValueError("Health cannot be negative")instance._health = valueclass Character:health = Health()  # 健康值由Health描述符管理def __init__(self, name: str):self.name = nameself._health = 100# 使用示例
warrior = Character("Conan")
warrior.health = 80  # 正常赋值
warrior.health = -10 # 抛出ValueError

四、进阶技巧:魔法方法的深度优化

1. 运算符重载的高级模式:自定义比较逻辑

通过__eq____lt__等方法,实现对象的比较操作:

class Version:def __init__(self, major: int, minor: int):self.major = majorself.minor = minordef __eq__(self, other: 'Version') -> bool:return self.major == other.major and self.minor == other.minordef __lt__(self, other: 'Version') -> bool:return (self.major, self.minor) < (other.major, other.minor)# 使用示例
v1 = Version(1, 2)
v2 = Version(1, 3)
print(v1 < v2)  # 输出:True

最佳实践

  • 使用functools.total_ordering:自动生成其他比较方法
  • 避免循环依赖:确保__eq____hash__一致
2. 协议的显式约束:使用抽象基类(ABC)

通过abc模块定义协议,强制子类实现必要方法:

from abc import ABC, abstractmethodclass Container(ABC):@abstractmethoddef __len__(self):pass@abstractmethoddef __getitem__(self, index):passclass MyList(Container):def __init__(self, *elements):self.elements = list(elements)def __len__(self):return len(self.elements)def __getitem__(self, index):return self.elements[index]# 验证协议实现
mylist = MyList(1, 2, 3)
isinstance(mylist, Container)  # 输出:True
3. 性能优化:缓存与惰性计算

通过__getattr____call__实现惰性加载与缓存:

class LazyLoader:def __getattr__(self, name: str):# 动态加载模块并缓存module = __import__(name)setattr(self, name, module)return moduledef __call__(self, func):# 装饰器实现def wrapper(*args, **kwargs):print(f"Calling {func.__name__}")return func(*args, **kwargs)return wrapper# 使用示例
loader = LazyLoader()
loader.math.sqrt(4)  # 动态加载math模块@loader  # 等价于@loader()
def add(a, b):return a + badd(1, 2)  # 输出:Calling add\n3

五、总结:从“代码工具”到“生态公民”的思维跃迁

本文展示了魔法方法与协议在提升类的Pythonic特性中的显著优势:

  • 自然交互:运算符重载、序列协议等让代码更易读
  • 生态融合:上下文管理、可调用对象等让类无缝融入Python生态
  • 复用性:描述符协议、抽象基类等实现逻辑复用

当然,魔法方法并非“银弹”。对于简单脚本或临时需求,过度使用可能导致代码复杂化。但在中大型项目中,尤其是需要与Python生态深度集成的系统,魔法方法能显著提升开发效率与系统稳定性。

行动建议

  1. 从简单魔法方法开始:先实现__str____repr__,提升对象的可读性
  2. 逐步应用协议:从序列协议(__len____getitem__)到上下文协议(__enter____exit__
  3. 学习标准库实现:参考collections.abc中的抽象基类,理解协议设计范式

通过“魔法方法与协议”这个维度,我们进一步理解了类的价值——它不仅是数据与行为的载体,更是与Python语言深度对话的“公民”。当类的魔法方法与协议设计与业务逻辑深度契合时,代码将成为Python生态的自然延伸,这正是面向对象编程的高阶应用。

相关文章:

Python类的力量:第五篇:魔法方法与协议——让类拥有Python的“超能力”

文章目录 前言&#xff1a;从“普通对象”到“Python原生公民”的进化之路 一、魔法方法&#xff1a;赋予对象“超能力”的基因1. 构造与析构&#xff1a;对象生命周期的“魔法开关”2. 字符串表示&#xff1a;对象的“自我介绍”3. 运算符重载&#xff1a;让对象支持“数学魔法…...

R S的EMI接收机面板

图片摘自R & S官网。 根据您提供的第一张图&#xff08;设备前面板带屏幕的图像&#xff09;&#xff0c;这是 Rohde & Schwarz ESRP7 EMI Test Receiver 的正面显示界面&#xff0c;我将对屏幕上显示的参数逐项进行解读&#xff1a; &#x1f5a5;️ 屏幕参数解读 左…...

pytorch nn.RNN demo

之前已经讲过关于RNNCell的实现了. 这里用LLM写了一个简单的nn.RNN demo&#xff1a; import torch import torch.nn as nn# 设置随机种子以便结果可复现 torch.manual_seed(42)# 定义模型参数 input_size 4 # 输入特征维度 hidden_size 8 # 隐藏层维度 num_layer…...

高防服务器流量“清洗”什么意思

在当今数字化的时代&#xff0c;网络安全成为了备受关注的焦点。其中&#xff0c;高防服务器流量“清洗”这个概念&#xff0c;对于许多朋友来说可能还比较陌生。今天&#xff0c;就让我们一起来揭开它神秘的面纱。 首先&#xff0c;咱们得明白&#xff0c;高防服务器流量“清…...

Unity3D开发AI桌面精灵/宠物系列 【六】 人物模型 语音口型同步 LipSync 、梅尔频谱MFCC技术、支持中英文自定义编辑- 基于 C# 语言开发

Unity3D开发AI桌面精灵/宠物系列 【六】 人物模型 语音口型同步 LipSync 、梅尔频谱MFCC技术 C# 语言开发 该系列主要介绍怎么制作AI桌面宠物的流程&#xff0c;我会从项目开始创建初期到最终可以和AI宠物进行交互为止&#xff0c;项目已经开发完成&#xff0c;我会仔细梳理一下…...

Java详解LeetCode 热题 100(17):LeetCode 41. 缺失的第一个正数(First Missing Positive)详解

文章目录 1. 题目描述2. 理解题目3. 解法一&#xff1a;排序法&#xff08;不满足题目要求&#xff09;3.1 思路3.2 Java代码实现3.3 代码详解3.4 复杂度分析3.5 不足之处 4. 解法二&#xff1a;哈希表法4.1 思路4.2 Java代码实现4.3 代码详解4.4 复杂度分析4.5 不足之处 5. 解…...

Kafka消息路由分区机制深度解析:架构设计与实现原理

一、消息路由系统的核心架构哲学 1.1 分布式系统的三元悖论 在分布式消息系统的设计过程中&#xff0c;架构师需要平衡三个核心诉求&#xff1a;数据一致性、系统可用性和分区容忍性。Kafka的分区路由机制本质上是对CAP定理的实践解&#xff1a; 一致性维度&#xff1a;通过…...

用C语言实现了——一个基于顺序表的插入排序演示系统

一、知识要点、 插入排序是一种简单直观的排序算法&#xff0c;它的工作方式类似于我们整理扑克牌。 基本原理&#xff1a; 插入排序通过构建有序序列来工作。它每次从无序序列中取出一个元素&#xff0c;然后将其插入到已排序序列的适当位置。这个过程重复进行&#xff0c;…...

linux libdbus使用案例

以下是一个基于 Linux libdbus 的详细指南,包含服务端和客户端的完整代码示例,涵盖 方法调用、信号发送 和 异步消息处理。libdbus 是 D-Bus 的底层 C 库,直接操作 D-Bus 协议,适合需要精细控制的场景。 1. libdbus 的核心机制 连接管理:通过 dbus_bus_get 连接系统总线或…...

Apple Vision Pro空间视频创作革命:从180度叙事到沉浸式语法的重构——《Adventure》系列幕后技术深度解析

🌌 引言:沉浸式媒体的“语法实验室” Apple Vision Pro的推出标志着空间计算时代的到来,而《Adventure》系列作为其原生内容标杆,正在成为沉浸式叙事的“语法实验室”。导演Charlotte Mikkelborg与播客主持人Kent Bye的对话揭示了这一领域的技术突破、创作挑战与行业生态…...

[特殊字符] 苍穹外卖项目中的 WebSocket 实战:实现来单与催单提醒功能

&#x1f680; 苍穹外卖项目中的 WebSocket 实战&#xff1a;实现来单与催单提醒功能 在现代 Web 应用中&#xff0c;实时通信成为提升用户体验的关键技术之一。WebSocket 作为一种在单个 TCP 连接上进行全双工通信的协议&#xff0c;被广泛应用于需要实时数据交换的场景&#…...

【C/C++】深度解析C++ Allocator:优化内存管理的关键

文章目录 深度解析C Allocator&#xff1a;优化内存管理的关键1 默认 std::allocator2 自定义 Allocator3 自定义 Allocator 的实现3.1 基本结构3.2 使用自定义 Allocator 4 关键特性详解4.1 rebind 机制4.2 状态化 Allocator 5 应用示例&#xff1a;内存池 Allocator5.1 简单内…...

gitlab+portainer 实现Ruoyi Vue前端CI/CD

1. 场景 最近整了一个Ruoyi Vue 项目&#xff0c;需要实现CICD&#xff0c;经过一番坎坷&#xff0c;最终达成&#xff0c;现将技术要点和踩坑呈现。 具体操作流程和后端大同小异&#xff0c;后端操作参考连接如下&#xff1a; https://blog.csdn.net/leinminna/article/detai…...

CAPL编程系列_04

1_ 测试模块TestModule&#xff1a;基本使用 1&#xff09;在Simulation Setup 中创建并配置 Test Module节点 2&#xff09;编写测试脚本 【1】测试用例函数&#xff08;testcase&#xff09;:实现具体测试逻辑 【2】主测试函数&#xff08;Main Test&#xff09;&…...

Weblogic SSRF漏洞复现(CVE-2014-4210)【vulhub靶场】

漏洞概述&#xff1a; Weblogic中存在一个SSRF漏洞&#xff0c;利用该漏洞可以发送任意HTTP请求&#xff0c;进而攻击内网中redis、fastcgi等脆弱组件。 漏洞形成原因&#xff1a; WebLogic Server 的 UDDI 组件&#xff08;uddiexplorer.war&#xff09;中的 SearchPublicR…...

科技的成就(六十八)

623、杰文斯悖论 杰文斯悖论是1865年经济学家威廉斯坦利杰文斯提出的一悖论&#xff1a;当技术进步提高了效率&#xff0c;资源消耗不仅没有减少&#xff0c;反而激增。例如&#xff0c;瓦特改良的蒸汽机让煤炭燃烧更加高效&#xff0c;但结果却是煤炭需求飙升。 624、代码混…...

知从科技闪耀2025上海车展:以创新驱动未来出行新篇章

上海&#xff0c;2025年4月23日——全球汽车科技领域的年度盛会——2025上海国际汽车工业展览会&#xff08;简称“上海车展”&#xff09;于5月2日圆满落幕。作为智能汽车软件与系统解决方案的领军企业&#xff0c;知从科技受邀参展&#xff0c;并在活动期间全方位展示了其在智…...

【iOS安全】Dopamine越狱 iPhone X iOS 16.6 (20G75) | 解决Jailbreak failed with error

Dopamine越狱 iPhone X iOS 16.6 (20G75) Dopamine兼容设备 参考&#xff1a;https://www.bilibili.com/opus/977469285985157129 A9 - A11&#xff08;iPhone6s&#xff0d;X&#xff09;&#xff1a;iOS15.0-16.6.1 A12-A14&#xff08;iPhoneXR&#xff0d;12PM&#xf…...

医疗数据迁移质量与效率的深度研究:三维六阶框架与实践创新

引言 随着医疗信息化建设的深入推进,医疗数据作为医疗机构的核心资产,其价值与日俱增。在医院信息系统升级、迁移或整合过程中,数据迁移的质量与效率直接关系到医疗服务的连续性、患者信息的安全性以及医院运营的稳定性。传统数据迁移方法往往面临时间长、风险高、成本大等…...

[6-8] 编码器接口测速 江协科技学习笔记(7个知识点)

1 2 在STM32微控制器的定时器模块中&#xff0c;CNT通常指的是定时器的计数器值。以下是CNT是什么以及它的用途&#xff1a; 是什么&#xff1a; • CNT&#xff1a;代表定时器的当前计数值。在STM32中&#xff0c;定时器从0开始计数&#xff0c;直到达到预设的自动重装载值&am…...

java类加载阶段与双亲委派机制

java执行过程:.java->.class->然后被jvm加载解释执行。 一、类加载机制的三个阶段 ​​加载&#xff08;Loading&#xff09;​​ ​​任务​​&#xff1a;通过类的全限定名获取二进制字节流&#xff08;如从文件系统、网络等&#xff09;&#xff0c;将字节流转换为方…...

医院网络安全托管服务(MSS)深度解读与实践路径

医疗行业网络安全挑战与MSS的应运而生 医疗行业在数智化转型的过程中面临着前所未有的网络安全挑战。根据2025年的最新数据&#xff0c;医疗行业将面临大量网络攻击&#xff0c;其中高达91%与勒索软件有关&#xff0c;且45%的数据泄露事件源于第三方供应商。医疗机构的平均数据…...

计算图存储采用矩阵吗,和张量关系

计算图存储采用矩阵吗,和张量关系 计算图的存储方式与张量的关系 一、计算图的存储方式 计算图(Computational Graph)是一种用于描述数学运算的有向无环图(DAG),其节点代表运算(如加减乘除、矩阵乘法、激活函数等),边代表运算的输入和输出(通常是张量)。计算图的…...

RPA 自动化实现自动发布

&#x1f4d5;我是廖志伟&#xff0c;一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》&#xff08;基础篇&#xff09;、&#xff08;进阶篇&#xff09;、&#xff08;架构篇&#xff09;清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、…...

博途软件直接寻址AMS348i读取位置值详解

一、AMS348i简介 AMS348i是一种高性能绝对值编码器&#xff0c;常用于工业自动化领域的位置检测。它具有以下特点&#xff1a; 高精度位置测量 多种通信接口&#xff08;如SSI、PROFIBUS、PROFINET等&#xff09; 坚固的工业设计 支持多种安装方式 二、元器件及配件 设备…...

MySQL 学习(十)执行一条查询语句的内部执行过程、MySQL分层

目录 一、MySQL 执行流程图二、MySQL的分层2.1 连接阶段2.2 查询缓存阶段&#xff08;Query Cache&#xff0c;MySQL 8.0已移除&#xff09;2.3 解析与预处理阶段&#xff08;词法分析、语法分析、预处理器&#xff09;2.4 查询优化阶段2.5 执行引擎阶段 三、常见面试题3.1 MyS…...

C语言中的指定初始化器

什么是指定初始化器? C99标准引入了一种更灵活、直观的初始化语法——指定初始化器(designated initializer), 可以在初始化列表中直接引用结构体或联合体成员名称的语法。通过这种方式,我们可以跳过某些不需要初始化的成员,并且可以以任意顺序对特定成员进行初始化。这…...

什么是 NB-IoT ?窄带IoT 应用

物联网使各种应用能够与大量无线通信设备进行连接和通信。它有望为智能城市、公用事业、制造设施、农业应用、远程工业机械等提供动力。这些应用均可使用窄带物联网&#xff08;NB-IoT &#xff09;网络协议。 例如&#xff0c;智能城市可使用 NB-IoT 监控整个城市的街道照明、…...

CSRF 和 XSS 攻击分析与防范

CSRF 和 XSS 攻击分析与防范 CSRF (跨站请求伪造) 什么是 CSRF&#xff1f; CSRF (Cross-Site Request Forgery) 是一种攻击方式&#xff0c;攻击者诱使用户在已登录目标网站的情况下&#xff0c;执行非预期的操作。 攻击流程&#xff1a; 用户登录可信网站 A在不登出 A 的…...

Window下Jmeter多机压测方法

1.概述 Jmeter多机压测的原理&#xff0c;是通过单个jmeter客户端&#xff0c;控制多个远程的jmeter服务器&#xff0c;使他们同步的对服务器进行压力测试。 以此方式收集测试数据的好处在于&#xff1a; 保存测试采样数据到本地机器通过单台机器管理多个jmeter执行引擎测试…...

Apache RocketMQ ACL 2.0 全新升级

&#x1f4d6;知识延伸&#xff1a;本文相关知识库已收录至「RocketMQ 中文社区」&#xff0c;同步更新更多进阶内容 引言 RocketMQ 作为一款流行的分布式消息中间件&#xff0c;被广泛应用于各种大型分布式系统和微服务中&#xff0c;承担着异步通信、系统解耦、削峰填谷和消…...

第九讲 | 模板进阶

模板进阶 一、非类型模板参数1、模板参数的分类2、应用场景3、array4、注意 二、模板的特化1、概念2、函数模板特化3、类模板特化&#xff08;1&#xff09;、全特化&#xff1a;全部模板参数都特化成具体的类型&#xff08;2&#xff09;、偏/半特化&#xff1a;部分模板参数特…...

联合建模组织学和分子标记用于癌症分类|文献速递-深度学习医疗AI最新文献

Title 题目 Joint modeling histology and molecular markers for cancer classification 联合建模组织学和分子标记用于癌症分类 01 文献速递介绍 癌症是对人类致命的恶性肿瘤&#xff0c;早期准确诊断对癌症治疗至关重要。目前&#xff0c;病理诊断仍是癌症诊断的金标准…...

会计要素+借贷分录+会计科目+账户,几个银行会计的重要概念

1.借贷分录还是借贷分路 正确表述是“借贷分录”。 “分录”即会计分录&#xff0c;它是指预先确定每笔经济业务所涉及的账户名称&#xff0c;以及计入账户的方向和金额的一种记录&#xff0c;简称分录。 在借贷记账法下&#xff0c;会计分录通过“借”和“贷”来表示记账方向…...

【C++】set和multiset的常用接口详解

前⾯我们已经接触过STL中的部分容器如&#xff1a;string、vector、list、deque、array、forward_list等&#xff0c;本篇文章将介绍一下map和multiset的使用。 1. 序列式容器和关联式容器 在介绍set之前我们先简单介绍一下什么是序列式容器和关联式容器。 前⾯我们已经接触过S…...

PostgreSQL 联合索引生效条件

最近面试的时候&#xff0c;总会遇到一个问题 在 PostgreSQL 中&#xff0c;联合索引在什么条件下会生效&#xff1f; 特此记录~ 前置信息 数据库版本 PostgreSQL 14.13, compiled by Visual C build 1941, 64-bit 建表语句 CREATE TABLE people (id SERIAL PRIMARY KEY,c…...

聊聊redisson的lockWatchdogTimeout

序 本文主要研究一下redisson的lockWatchdogTimeout lockWatchdogTimeout redisson/src/main/java/org/redisson/config/Config.java private long lockWatchdogTimeout 30 * 1000;/*** This parameter is only used if lock has been acquired without leaseTimeout param…...

数据结构第七章(三)-树形查找:红黑树

树形查找&#xff08;二&#xff09; 红黑树一、红黑树1.定义2.黑高3.性质 二、插入1.插入步骤2.举例 总结 红黑树 红黑树来喽~ 我们在上一篇说了二叉排序树&#xff08;BST&#xff09;和平衡二叉树&#xff08;AVL&#xff09;&#xff0c;那么既然都有这两个了&#xff0c;…...

C++篇——多态

目录 引言 1&#xff0c;什么是多态 2. 多态的定义及实现 2_1&#xff0c;多态的构成条件 2_2&#xff0c;虚函数 2_3&#xff0c;虚函数的重写 2_4&#xff0c;虚函数重写的两个例外 2_4_1&#xff0c;协变(基类与派生类虚函数返回值类型不同) 2_4_2. 析构函数的重写(基类…...

AI实时对话的通信基础,WebRTC技术综合指南

在通过您的网络浏览器进行音频和视频通话、屏幕共享或实时数据传输时&#xff0c;您可能并不常思考其背后的技术。推动这些功能的核心力量之一就是WebRTC。2011年由谷歌发布的这个开源项目&#xff0c;如今已发展成为一个高度全面且不断扩展的生态系统。尤其是在AI技术大幅突破…...

【寻找Linux的奥秘】第五章:认识进程

请君浏览 前言1. 冯诺依曼体系结构数据流动 2. 操作系统&#xff08;Operating System&#xff09;2.1 概念2.2 设计OS的目的2.3 如何理解“管理”2.4 系统调用和库函数概念 3. 进程3.1 基本概念3.1.1 查看进程3.1.2 创建进程 3.2 进程状态3.2.1 简单介绍3.2.2 运行&&阻…...

uniapp微信小程序-长按按钮百度语音识别回显文字

流程图&#xff1a; 话不多说&#xff0c;上代码&#xff1a; <template><view class"content"><view class"speech-chat" longpress"startSpeech" touchend"endSpeech"><view class"animate-block" …...

支付宝创建商家订单收款码(统一收单线下交易预创建).net开发的软件附带大型XML文件可以删除吗?AlipaySDKNet.OpenAPI.xml

支付宝创建商家订单收款码&#xff08;统一收单线下交易预创建&#xff09;一个程序55MB&#xff0c;XML就带了35MB AlipaySDKNet.OpenAPI.xml&#xff0c;BouncyCastle.Crypto.xml 支付宝店铺收款码创建的程序&#xff0c;这些文件可以不用吗 在支付宝店铺收款码创建的程序中…...

Profinet转Ethernet/IP网关模块通信协议适配配置

案例背景 在某自动化生产车间中&#xff0c;现有控制系统采用了西门子 S7 - 1500 PLC 作为主要控制器&#xff0c;负责生产流程的核心控制。同时&#xff0c;由于部分设备的历史原因&#xff0c;存在使用 AB 的 PLC 进行特定环节控制的情况。为了实现整个生产系统的信息交互与…...

4.6/Q1,GBD数据库最新文章解读

文章题目&#xff1a;Global burden, subtype, risk factors and etiological analysis of enteric infections from 1990-2021: population based study DOI&#xff1a;10.3389/fcimb.2025.1527765 中文标题&#xff1a;1990-2021 年肠道感染的全球负担、亚型、危险因素和病因…...

数字孪生技术:开启未来的“镜像”技术

想象一下&#xff0c;你拥有一个与现实世界一模一样的 “数字分身”&#xff0c;它不仅长得像你&#xff0c;行为举止、思维方式也和你毫无二致&#xff0c;甚至能提前预知你的下一步行动。这听起来像是科幻电影里的情节&#xff0c;但数字孪生技术却让它在现实中成为了可能。数…...

Java 序列化(Serialization)

一、理论说明 1. 序列化的定义 Java 序列化是指将对象转换为字节流的过程&#xff0c;以便将其存储到文件、数据库或通过网络传输。反序列化则是将字节流重新转换为对象的过程。通过实现java.io.Serializable接口&#xff0c;类可以被标记为可序列化的&#xff0c;该接口是一…...

Python解析Excel入库如何做到行的拆分

我们读取解析Excel入库经常会遇到这种场景&#xff0c;那就是行的拆分&#xff0c;如图&#xff1a; 比如我们入库&#xff0c;要以name为主键&#xff0c;可是表格name的值全是以逗号分割的多个&#xff0c;这怎么办呢&#xff1f;这就必须拆成多行了啊。 代码如下&#xff…...

信创国产化监控 | 达梦数据库监控全解析

达梦数据库&#xff08;DM Database&#xff09;是国产数据库的代表产品之一&#xff0c;在政府、金融、电信、能源等多个关键行业应用广泛&#xff0c;它具有高兼容性、高安全性、高可用性、高性能、自主可控等特点。随着国产化替代进程加速&#xff0c;达梦数据库在关键信息基…...

Parsec解决PnP连接失败的问题

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、准备环境二、DMZ三、端口映射1.Parsec设置固定端口2.路由器设置端口转发3.重启被控端Parsec四、多少一句1.有光猫管理员账号2.没有光猫管理员账号总结 前言…...