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

奇怪的Python:为何字符串要设置成不可变的?

你好!我是老邓。今天我们来聊聊 Python 中字符串不可变这个话题。

1、问题简介:

Python 中,字符串属于不可变对象。这意味着一旦字符串被创建,它的值就无法被修改。任何看似修改字符串的操作,实际上都是创建了一个新的字符串。

2、假设我们要实现一个函数,将传入的字符串中的所有空格替换为下划线。

 
def replace_space(s):for i in range(len(s)):if s[i] == ' ':s[i] = '_'  #  尝试直接修改字符串中的字符return stest_str = "hello world"
new_str = replace_space(test_str)
print(new_str)

运行这段代码会报错 TypeError: 'str' object does not support item assignment 。这就是因为字符串是不可变的,我们不能像列表那样直接修改其中的字符。

3、原因和解决方案:

字符串的不可变性是由 Python 的底层实现决定的。这种设计带来了几个好处:

  • 哈希值稳定: 不可变性保证了字符串的哈希值是稳定的,因此字符串可以作为字典的键。

  • 线程安全: 多个线程可以安全地访问同一个字符串,无需担心数据竞争。

  • 内存优化: 在某些情况下,Python 可以对不可变字符串进行优化,例如字符串驻留 (string interning),从而减少内存占用。

要修改字符串,我们需要创建新的字符串。以下提供几种解决方案:

  • 使用字符串的内置方法: 例如 replace()、join() 等。

  • 切片和拼接: 通过切片获取字符串的各个部分,然后拼接成新的字符串。

  • 使用 `bytearray`: 如果需要频繁修改字符串内容,可以使用 bytearray 类型,它是一个可变的字节序列。

4、代码示例:

示例 1:使用 `replace()` 方法

 
def replace_space_with_replace(s):return s.replace(' ', '_')test_str = "hello world"
new_str = replace_space_with_replace(test_str)
print(new_str)  # 输出:hello_world

示例 2:使用切片和拼接

 
def replace_space_with_slice(s):new_s = ""for char in s:if char == ' ':new_s += '_'else:new_s += charreturn new_stest_str = "hello world"
new_str = replace_space_with_slice(test_str)
print(new_str)  # 输出:hello_world

示例 3:使用列表推导式和 `join()` 方法

 
def replace_space_with_join(s):return "".join(['_' if char == ' ' else char for char in s])test_str = "hello world"
new_str = replace_space_with_join(test_str)
print(new_str)  # 输出:hello_world

示例 4:使用 `bytearray` (适用于需要频繁修改的情况)

 
def replace_space_with_bytearray(s):b = bytearray(s, 'utf-8')for i in range(len(b)):if b[i] == ord(' '):b[i] = ord('_')return b.decode('utf-8')test_str = "hello world"
new_str = replace_space_with_bytearray(test_str)
print(new_str)  # 输出:hello_world

5、总结:

Python 字符串的不可变性是其语言设计的一部分,带来了性能和安全方面的优势。理解这一点对于编写高效、正确的 Python 代码至关重要。 

当需要修改字符串内容时,我们应该使用合适的方法创建新的字符串,而不是试图直接修改原字符串。

相关文章:

奇怪的Python:为何字符串要设置成不可变的?

你好!我是老邓。今天我们来聊聊 Python 中字符串不可变这个话题。 1、问题简介: Python 中,字符串属于不可变对象。这意味着一旦字符串被创建,它的值就无法被修改。任何看似修改字符串的操作,实际上都是创建了一个新…...

Vue-Router之嵌套路由

在路由配置中,配置children import Vue from vue import VueRouter from vue-routerVue.use(VueRouter)const router new VueRouter({mode: history,base: import.meta.env.BASE_URL,routes: [{path: /,redirect: /home},{path: /home,name: home,component: () &…...

MyBatis使用的设计模式

目录 1. 工厂模式(Factory Pattern) 2. 单例模式(Singleton Pattern) 3. 代理模式(Proxy Pattern) 4. 装饰器模式(Decorator Pattern) 5. 观察者模式(Observer Patt…...

arm rk3588 升级glibc2.31到2.33

一、查看glibc版本 rootztl:~# ldd --version ldd (Ubuntu GLIBC 2.31-0ubuntu9.2) 2.31 Copyright (C) 2020 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNE…...

【Linux系列】sed命令的深入解析:如何使用sed删除文件内容

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

C++ 设计模式:桥接模式(Bridge Pattern)

链接:C 设计模式 链接:C 设计模式 - 装饰模式 桥接模式(Bridge Pattern)是一种结构型设计模式,它通过将抽象部分(业务功能)与实现部分(平台实现)分离,使它们…...

MATLAB中whitespacePattern函数用法

目录 语法 说明 示例 匹配空白字符 替换非标准空白 更正错误的间距 whitespacePattern函数的功能是匹配空白字符。 语法 pat whitespacePattern pat whitespacePattern(N) pat whitespacePattern(minCharacters,maxCharacters) 说明 pat whitespacePattern 创建一…...

Django多字段认证的实现

Django多字段认证 需求: django认证的检查用户是username,如果使用 username和 手机号验证登录。 重写: ModelBackend 类下的 authenticate 方法 # 在对应应用下创建 utils.py""" 修改Django认证类,为了实现 …...

【AndroidAPP】权限被拒绝:[android.permission.READ_EXTERNAL_STORAGE],USB设备访问权限系统报错

一、问题原因 1.安卓安全性变更 Android 12 的安全性变更,Google 引入了更严格的 PendingIntent 安全管理,强制要求开发者明确指定 PendingIntent 的可变性(Mutable)或不可变性(Immutable)。 但是&#xf…...

SQL进阶技巧:如何分析连续签到领金币数问题?

目录 0 题目需求 1 数据准备 2 问题分析 2.1 代码实现 2.2 代码功能分析 第一段 SQL...

1、ELK的架构和安装

ELK简介 elk:elasticsearch logstash kibana,统一日志收集系统。 elasticsearch:分布式的全文索引引擎的非关系数据库,json格式,在elk中存储所有的日志信息,架构有主和从,最少需要2台。 …...

Vue2/Vue3使用DataV

Vue2 注意vue2与3安装DataV命令命令是不同的Vue3 DataV - Vue3 官网地址 注意vue2与3安装DataV命令命令是不同的 vue3vite 与 Vue3webpack 对应安装也不同vue3vite npm install kjgl77/datav-vue3全局引入 // main.ts中全局引入 import { createApp } from vue import Da…...

汇编环境搭建

学习视频 将MASM所在目录 指定为C盘...

Android 系统 `android.app.Fragment` 类的深度定制与常见问题解析

Android 系统 android.app.Fragment 类的深度定制与常见问题解析 目录 引言Fragment 概述Fragment 的生命周期Fragment 的系统层深度定制 4.1 Fragment 的创建与初始化4.2 Fragment 的布局与视图4.3 Fragment 的通信机制4.4 Fragment 的动画与过渡4.5 Fragment 的状态保存与恢…...

linux ueditor nginx https 后台配置项返回格式出错,上传功能将不能正常使用

jsp的版本 如果出现了这个错误,上传的图标都亮起的情况,还是提示这个, 可以试试修改 uedtior.all.js 8082行 isJsonp utils.isCrossDomainUrl(configUrl); 改为 // isJsonp utils.isCrossDomainUrl(configUrl); isJsonp true; 如果还不…...

【机器学习 | 数据挖掘】时间序列算法

时间序列是按时间顺序排列的、随时间变化且相互关联的数据序列。分析时间序列的方法构成数据分析的一个重要领域,即时间序列分析。以下是对时间序列算法的详细介绍: 一、时间序列的分类 时间序列根据所研究的依据不同,可有不同的分类&#…...

uniapp H5 对接 声网,截图

文章目录 安装依赖创建容器容器样式 javascript代码ImageDataToBlob 方法 控制控制台LOG输出 安装依赖 版本"agora-rtc-sdk-ng": "^4.22.0", 创建容器 <template><view class"videoValue " id"videoValue"><u-toast…...

家谱管理系统|Java|SSM|VUE| 前后端分离

【技术栈】 1⃣️&#xff1a;架构: B/S、MVC 2⃣️&#xff1a;系统环境&#xff1a;Windowsh/Mac 3⃣️&#xff1a;开发环境&#xff1a;IDEA、JDK1.8、Maven、Mysql5.7 4⃣️&#xff1a;技术栈&#xff1a;Java、Mysql、SSM、Mybatis-Plus、VUE、jquery,html 5⃣️数据库…...

【LeetCode】200、岛屿数量

【LeetCode】200、岛屿数量 文章目录 一、并查集1.1 并查集1.2 多语言解法 二、洪水填充 DFS2.1 洪水填充 DFS 一、并查集 1.1 并查集 // go var sets int var father [90000]intfunc numIslands(grid [][]byte) int {n, m : len(grid), len(grid[0])build(grid, n, m)for i …...

idea报错:There is not enough memory to perform the requested operation.

文章目录 一、问题描述二、先解决三、后原因&#xff08;了解&#xff09; 一、问题描述 就是在使用 IDEA 写代码时&#xff0c;IDEA 可能会弹一个窗&#xff0c;大概提示你目前使用的 IDEA 内存不足&#xff0c;其实就是提醒你 JVM 的内存不够了&#xff0c;需要重新分配。弹…...

HLK-V20语音模块的智能家居实战:如何用STM32控制灯、电机并连接ESP8266上云

HLK-V20语音模块的智能家居实战&#xff1a;STM32联动控制与云端接入全解析 在智能家居DIY领域&#xff0c;语音控制早已从概念走向现实。HLK-V20作为一款高性价比的纯离线语音识别模块&#xff0c;配合STM32的丰富外设控制能力&#xff0c;可以构建出响应迅速、隐私安全的本地…...

51单片机控制LED灯实现流水灯效果(程序+Proteus仿真)

51单片机控制LED灯实现流水灯效果&#xff08;程序Proteus仿真&#xff09; 【下载地址】51单片机控制LED灯实现流水灯效果程序Proteus仿真 本资源提供了一个完整的项目&#xff0c;使用51单片机控制LED灯实现流水灯效果。资源内容包括Keil5 C语言程序和Proteus软件仿真文件&am…...

LOCAL_SENSITIVE_PATTERNS:不经过大模型的本地正则补强:开源免费的WPS AI 软件 察元AI文档助手

LOCAL_SENSITIVE_PATTERNS:不经过大模型的本地正则补强 摘要 本文围绕标题所述主题,结合本仓库当前源码行进行说明。仅供技术理解与内部培训,不构成定密、法务或密码测评结论。文中代码块均摘自本地仓库对应路径与行号。 正文 0. 结论先行 结论先行:保密检查由内置助手…...

Android项目集成CH340串口驱动:从官方Demo到体温检测模块的完整配置流程

Android项目集成CH340串口驱动&#xff1a;从官方Demo到体温检测模块的完整配置流程 在医疗设备、工业控制等物联网场景中&#xff0c;Android设备与外围硬件通过串口通信的需求日益增长。CH340作为一款高性价比的USB转串口芯片&#xff0c;因其稳定性和广泛兼容性成为许多硬件…...

AI 编程能力实战基准测试报告:编程能力评估体系 (Programming Capability Benchmark)

&#x1f916; AI 编程能力实战基准测试报告&#xff1a;编程能力评估体系 (Programming Capability Benchmark) 文件目标: 一份用于评估当前顶级生成式模型&#xff08;如GPT-5.5, Claude 4.7, Deepseek V4等&#xff09;实际软件开发能力和系统级思维的权威指南。 核心原则: …...

DIY便携UV美甲灯:从电路设计到3D打印的完整制作指南

1. 项目概述&#xff1a;为什么选择DIY一个便携UV美甲灯&#xff1f;如果你和我一样&#xff0c;是个喜欢自己动手做美甲&#xff0c;同时又对电子制作和3D打印有点“手痒”的爱好者&#xff0c;那你肯定对市面上那些笨重、必须插电的UV美甲灯感到过不满。它们要么像个小型烤箱…...

企业智能体如何高效快速部署落地,这N个细节需要注意

随着企业级智能体技术的日趋成熟&#xff0c;越来越多企业将其作为数字化转型的重要抓手&#xff0c;期望通过智能体提升业务效率、降低运营成本。但现实中&#xff0c;多数企业陷入“部署慢、落地难、效果差”的困境&#xff1a;有的耗时数月仍无法正常上线&#xff0c;有的上…...

LM265 手持式频谱分析仪:交通超宽频监测旗舰

LM265 手持式频谱分析仪是成都鼎讯信通科技打造的超宽频高性能便携设备&#xff0c;覆盖 9kHz~26.5GHz&#xff0c;射频指标对标台式仪器&#xff0c;兼顾便携与精度&#xff0c;为铁路、高速等交通领域提供全频段信号监测与干扰排查能力。设备集成频谱分析、场强测量、信道扫描…...

从零上手RP2040:为树莓派Pico注入MicroPython灵魂

1. 为什么选择MicroPython&#xff1f; 对于刚接触树莓派Pico&#xff08;RP2040&#xff09;的新手来说&#xff0c;选择MicroPython作为开发语言是个明智的决定。这就像第一次学骑自行车时选择带辅助轮的车子——它降低了入门门槛&#xff0c;让你能快速感受到编程的乐趣。Mi…...

CodeWF.Markdown:一个基于 Avalonia 12 的 Markdown 渲染控件

今天这篇文章&#xff0c;站长来聊聊我最近基本开发完成的 CodeWF.Markdown。这是一个基于 C# Avalonia 12 Markdig 做的 Markdown 渲染控件。它最早来自 CodeWF.AvaloniaControls&#xff0c;后来我把 Markdown 相关代码单独拆成了一个仓库和一组 NuGet 包&#xff1a;渲染控…...