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

从Python面试题看mutable和immutable:为什么面试官总爱问a+=b和a=a+b的区别?

从Python面试题看mutable和immutable为什么面试官总爱问ab和aab的区别在Python面试中a b和a a b的区别几乎是必考题。这看似简单的语法差异背后隐藏着Python对象可变性mutable与不可变性immutable的核心机制。理解这一机制不仅能帮助你在面试中脱颖而出更能让你在日常开发中避免许多隐蔽的bug。1. 可变与不可变Python对象的本质差异Python中的所有数据都是对象每个对象都有三个基本属性标识identity对象在内存中的唯一地址可通过id()函数获取类型type对象的数据类型决定对象支持的操作值value对象存储的实际数据根据值能否被修改Python对象分为两大类特性可变对象mutable不可变对象immutable创建后值能否改变是否内存地址是否固定是否修改时创建新对象常见类型list, dict, setint, float, str, tuple关键区别在于可变对象支持原地修改in-place modification而不可变对象的任何修改操作都会创建新对象。# 可变对象示例 lst [1, 2, 3] print(id(lst)) # 输出原始内存地址 lst.append(4) # 原地修改 print(id(lst)) # 地址不变 # 不可变对象示例 s hello print(id(s)) # 输出原始内存地址 s world # 创建新对象 print(id(s)) # 地址改变2.操作符的双重人格操作符在Python中被称为增量赋值运算符但其行为会根据操作对象的可变性而完全不同2.1 对于可变对象如列表a b会调用对象的__iadd__方法执行原地修改lst1 [1, 2] lst2 lst1 lst1 [3] # 等价于 lst1.__iadd__([3]) print(lst1) # [1, 2, 3] print(lst2) # [1, 2, 3] (lst2也受影响)2.2 对于不可变对象如元组a b会退化为a a b创建新对象tup1 (1, 2) tup2 tup1 tup1 (3,) # 等价于 tup1 tup1 (3,) print(tup1) # (1, 2, 3) print(tup2) # (1, 2) (tup2不受影响)面试陷阱以下代码会输出什么def func(a[]): a [1] return a print(func()) # [1] print(func()) # [1, 1]这个例子展示了可变默认参数的常见陷阱。由于列表是可变的操作会修改同一个默认列表对象。3. 字典键的不可变要求Python要求字典的键必须是不可变对象这直接关系到哈希机制不可变对象在创建后哈希值不变可以安全作为键可变对象哈希值可能改变导致字典内部哈希表混乱# 合法使用元组作为键 valid_dict {(1, 2): value} # 非法尝试使用列表作为键 try: invalid_dict {[1, 2]: value} except TypeError as e: print(e) # 输出unhashable type: list实用技巧当需要使用复合键时可以将可变对象转换为不可变对象data {} key [1, 2, 3] data[tuple(key)] value # 将列表转换为元组4. 函数参数传递的微妙差异Python采用对象引用传递函数内对参数的修改是否会影响外部变量取决于对象的可变性4.1 不可变参数示例def modify_num(x): x 10 print(f函数内x: {x}, id: {id(x)}) num 5 print(f调用前num: {num}, id: {id(num)}) modify_num(num) print(f调用后num: {num}, id: {id(num)})输出显示函数内外的num是不同的对象原始变量不受影响。4.2 可变参数示例def modify_list(lst): lst.append(4) print(f函数内lst: {lst}, id: {id(lst)}) my_list [1, 2, 3] print(f调用前my_list: {my_list}, id: {id(my_list)}) modify_list(my_list) print(f调用后my_list: {my_list}, id: {id(my_list)})输出显示函数内外操作的是同一个列表对象原始变量被修改。防御性编程建议如果函数不应修改传入的可变参数应先创建副本def safe_modify(lst): lst list(lst) # 创建副本 lst.append(4) return lst5. 实际工程中的选择策略理解可变性后在实际开发中应遵循以下原则优先使用不可变对象减少意外修改的风险提高代码可预测性明确文档约定对于需要修改可变参数的函数应在文档中明确说明注意线程安全可变对象在多线程环境下需要额外同步措施性能权衡频繁修改的小对象使用可变类型大对象或配置数据使用不可变类型# 性能对比示例 import timeit # 字符串拼接不可变 def concat_immutable(): s for i in range(1000): s str(i) # 列表拼接可变 def concat_mutable(): lst [] for i in range(1000): lst.append(str(i)) .join(lst) print(不可变:, timeit.timeit(concat_immutable, number1000)) print(可变:, timeit.timeit(concat_mutable, number1000))测试结果显示可变对象方案通常性能更优但需要权衡可维护性。

相关文章:

从Python面试题看mutable和immutable:为什么面试官总爱问a+=b和a=a+b的区别?

从Python面试题看mutable和immutable:为什么面试官总爱问ab和aab的区别? 在Python面试中,a b和a a b的区别几乎是必考题。这看似简单的语法差异背后,隐藏着Python对象可变性(mutable)与不可变性&#xf…...

从信号到异常:深入Linux/Python终端,拆解Ctrl+C(KeyboardInterrupt)的完整生命周期

从信号到异常:深入Linux/Python终端,拆解CtrlC(KeyboardInterrupt)的完整生命周期 当你在终端按下CtrlC时,这个看似简单的操作背后隐藏着一套精密的系统级协作机制。本文将带你穿越操作系统信号处理、终端驱动层、解释…...

开源VGA转HDMI转换板硬件设计与开发指南

1. Olimex VGA2HDMI开源转换板深度解析 作为一名长期从事嵌入式硬件开发的工程师,我最近测试了Olimex推出的这款开源VGA转HDMI转换板。与市面上常见的闭源转换器不同,这款产品从硬件设计到固件都完全开放,对于开发者社区而言具有特殊价值。 …...

5分钟快速上手:终极自动化学习助手解放你的时间

5分钟快速上手:终极自动化学习助手解放你的时间 【免费下载链接】Autovisor 2025智慧树刷课脚本 基于Python Playwright的自动化程序 [有免安装版] 项目地址: https://gitcode.com/gh_mirrors/au/Autovisor 你是否厌倦了每天重复点击播放、等待视频结束、手动…...

AI智能体技能化开发:模块化、复用与工程实践指南

1. 项目概述:从“技能”视角重构智能体开发 最近在折腾AI智能体(Agent)项目时,我遇到了一个几乎所有开发者都会碰到的瓶颈:随着智能体功能越来越复杂,代码库变得臃肿不堪,不同功能的逻辑相互耦合…...

微软开源DOS 1.0!当年用不到10万美元拿下的代码,改写了整个操作系统史

整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 当一个系统彻底退出历史舞台,它的命运通常只有两个:被遗忘,或者被封存。但微软选了第三条路——把它开源出来。 如今恰逢 86-DOS 1.00 诞生 45 周年,微软…...

Pseudogen:如何用3步将Python代码转化为人人都能看懂的伪代码?

Pseudogen:如何用3步将Python代码转化为人人都能看懂的伪代码? 【免费下载链接】pseudogen A tool to automatically generate pseudo-code from source code. 项目地址: https://gitcode.com/gh_mirrors/ps/pseudogen 你是否曾面对复杂的Python代…...

使用Nodejs和Taotoken快速构建一个智能客服对话接口

使用Nodejs和Taotoken快速构建一个智能客服对话接口 1. 项目初始化与环境准备 在开始构建智能客服对话接口前,需要确保开发环境已配置Node.js运行环境。推荐使用Node.js 18或更高版本,以获得最佳的异步处理性能。通过以下命令可以检查当前Node.js版本&…...

微信小程序逆向工程实战:wxappUnpacker技术深度剖析与高效应用指南

微信小程序逆向工程实战:wxappUnpacker技术深度剖析与高效应用指南 【免费下载链接】wxappUnpacker forked from https://github.com/qwerty472123/wxappUnpacker 项目地址: https://gitcode.com/gh_mirrors/wxappu/wxappUnpacker 微信小程序作为移动互联网的…...

EPICS s7nodave从编译到实战:手把手配置IOC连接S7-1200 PLC(含轮询组优化)

EPICS s7nodave从编译到实战:手把手配置IOC连接S7-1200 PLC(含轮询组优化) 在工业自动化领域,EPICS(Experimental Physics and Industrial Control System)与西门子S7系列PLC的通信一直是工程师们关注的焦…...

C++集成OpenAI API实战:liboai库核心设计与应用指南

1. 项目概述:一个现代、简洁的OpenAI API C客户端如果你正在用C做项目,又想集成像GPT-4、DALLE这样的AI能力,大概率会面临一个选择:是直接用官方的Python/Node.js SDK,然后费劲地搞语言绑定,还是自己从零开…...

零代码构建AI智能体:agentforge-openclaw核心架构与实战指南

1. 项目概述:构建无需代码的智能体技能工厂 最近在探索AI智能体开发时,我发现了一个对新手和想快速验证想法的开发者特别友好的工具—— agentforge-openclaw 。简单来说,它就像一个“智能体技能工厂”,让你不用写一行代码&…...

基于MCP协议为AI助手集成实时加密市场数据:CoinPaprika MCP Server实战指南

1. 项目概述:为AI助手注入实时加密市场数据如果你正在使用Claude、Cursor这类AI编程助手,并且需要频繁查询加密货币的实时价格、交易所数据或项目信息,那么手动复制粘贴数据或者切换浏览器标签页绝对是一种效率杀手。CoinPaprika MCP Server的…...

Intel FSP技术架构与HOB机制详解

1. Intel FSP技术架构解析 Intel Firmware Support Package(FSP)是英特尔为x86平台提供的预集成固件模块,它封装了处理器和芯片组的初始化代码。作为UEFI固件开发的核心组件,FSP采用模块化设计,主要包含以下三个关键阶…...

金融交易中LLM的应用与挑战

1. 金融交易场景下的LLM应用现状大型语言模型(LLM)在金融交易领域的渗透正在改变传统量化分析的范式。过去三年间,华尔街至少有47家对冲基金开始部署GPT-4级别模型处理实时行情数据,而高频交易公司Jane Street的测试显示&#xff…...

视觉-物理对齐:机器人学习中的3D空间理解新范式

1. 视觉-物理对齐:机器人学习的新范式 在机器人学习领域,视觉-语言-动作(VLA)模型正逐渐成为主流范式。这类模型通过整合视觉感知与语言指令理解,指导机器人与物理世界进行交互。然而,当前大多数VLA模型面临…...

别再只会点Send了!Burp Repeater的5个高阶用法,让渗透测试效率翻倍

别再只会点Send了!Burp Repeater的5个高阶用法,让渗透测试效率翻倍 当你已经能熟练使用Burp Repeater发送请求、修改参数时,是否感觉测试效率遇到了瓶颈?实际上,这个看似简单的工具隐藏着许多能大幅提升手动测试深度的…...

别再手动复制代码了!用Git Submodule优雅管理多仓库依赖(以Vue3 + Element Plus项目为例)

别再手动复制代码了!用Git Submodule优雅管理多仓库依赖(以Vue3 Element Plus项目为例) 当你在开发一个Vue3后台管理系统时,是否经常遇到这样的场景:需要复用公司内部的UI组件库、工具函数库或者微服务SDK&#xff1…...

将Hermes Agent工具连接到Taotoken平台的具体配置步骤

将Hermes Agent工具连接到Taotoken平台的具体配置步骤 1. 准备工作 在开始配置前,请确保已安装Hermes Agent工具并拥有有效的Taotoken API Key。API Key可在Taotoken控制台的"API密钥管理"页面创建。同时建议在模型广场查看可用的模型ID,后续…...

MTKClient终极指南:解锁联发科设备的底层操作神器

MTKClient终极指南:解锁联发科设备的底层操作神器 【免费下载链接】mtkclient MTK reverse engineering and flash tool 项目地址: https://gitcode.com/gh_mirrors/mt/mtkclient MTKClient是一款专为联发科(MediaTek)芯片设备设计的开…...

BetterGI:用AI技术重新定义《原神》游戏体验的革命性工具

BetterGI:用AI技术重新定义《原神》游戏体验的革命性工具 【免费下载链接】better-genshin-impact 📦BetterGI 更好的原神 - 自动拾取 | 自动剧情 | 全自动钓鱼(AI) | 全自动七圣召唤 | 自动伐木 | 自动刷本 | 自动采集/挖矿/锄地 | 一条龙 | 全连音游 …...

ECS ARM 改造 — 多架构基础镜像构建指南

1. 背景 ECS Fargate ARM 改造时,业务 Dockerfile 的 FROM 基础镜像必须支持 ARM 架构。我们的私有 ECR 基础镜像(jdk:11-jre-ttl、jdk:11-jre-sw 等)只有 X86 版本,直接用 buildx 构建 ARM 镜像会导致 exec format error。 解决方案:基于官方多架构镜像重建私有基础镜像…...

告别手动切换!在嵌入式Linux上实现RS485自动收发控制的三种方法(附i.MX6ULL代码)

嵌入式Linux RS485自动收发控制实战:三种高效方案与i.MX6ULL实现详解 在工业自动化、智能仪表和远程监控系统中,RS485总线因其出色的抗干扰能力和长距离传输特性,成为设备间通信的首选方案。然而传统RS485开发中最大的痛点莫过于需要手动控制…...

别再死记硬背Redis命令了!用Spring Data Redis的opsForValue()帮你无缝衔接redis-cli

从redis-cli到Spring Data Redis:用opsForValue()构建无缝编程体验 Redis作为高性能键值数据库,其命令行工具redis-cli是开发者最熟悉的操作界面。但当我们将Redis集成到Spring应用中时,Spring Data Redis提供的抽象API常常让习惯了命令行的…...

GRPO与DPO的对比学习视角及优化策略

1. 从对比学习视角看GRPO与DPO的内在关联 最近在优化语言模型对齐策略时,我注意到GRPO(Generalized Reinforcement Policy Optimization)和DPO(Direct Preference Optimization)这两种方法在数学形式上存在某种有趣的对…...

别再只盯着准确率了!用Python手把手教你画出分类模型的PR和ROC曲线(附代码)

实战指南:用Python绘制分类模型的PR与ROC曲线 在机器学习项目中,评估分类模型性能时,很多开发者习惯性地依赖单一准确率指标,这往往会导致对模型真实效果的误判。特别是在样本分布不均衡的场景下,准确率可能给出极具误…...

用Python玩转Jetson Nano串口:一个脚本实现数据收发与回显测试

用Python玩转Jetson Nano串口:一个脚本实现数据收发与回显测试 在物联网和嵌入式开发中,串口通信就像设备之间的"普通话"——简单、通用且无处不在。Jetson Nano作为一款强大的边缘计算设备,其UART串口功能让开发者能够轻松连接各…...

告别VSCode!用Qt Creator 10.0.1 + ROS Noetic打造你的专属机器人开发IDE(含Qt组件集成指南)

Qt Creator 10.0.1 ROS Noetic:打造机器人开发的终极生产力工具链 在机器人开发领域,工具链的选择往往决定了开发效率的上限。当大多数开发者还在VSCode、CLion和终端之间频繁切换时,一个被低估的解决方案正在悄然崛起——Qt Creator 10.0.1…...

为AI智能体构建带权限的知识图谱记忆系统:架构、部署与实战

1. 项目概述:为AI智能体构建带权限的知识图谱记忆系统 在构建复杂的AI智能体时,一个核心挑战是如何让它们拥有“记忆”——不仅仅是记住对话历史,而是能像人类一样,将信息结构化地存储、关联,并在需要时精准地回忆起来…...

微软Bing视觉搜索优化:多模态AI与GPU加速实践

1. 微软Bing视觉搜索优化项目概述 微软Bing视觉搜索是一项革命性的图像检索技术,它允许用户通过上传照片来搜索网络上的相关内容。这项技术的核心是微软的TuringMM视觉嵌入模型,该模型能够将图像和文本映射到一个共享的高维空间中。每天需要处理数十亿张…...