網(wǎng)站首頁 編程語言 正文
Python列表的append()方法踩坑
在這之前,我一直認(rèn)為append()只是個將一個對象添加到列表尾部的方法,但是今天之后,我對它有了一個新的認(rèn)識。
一般情況下,我們都是這樣使用:
list = [1,2,3]
list.append(4)
# list列表就變成了[1,2,3,4]
但是在后來的使用中,遇到了像下面這樣的問題:
a = [1,2]
b = []
b.append(a)
print(b)
a.append(3)
print(b)
# 此時b的結(jié)果為[[1,2,3]]
# 是的,你沒看錯,就是[[1,2,3]]
?明明兩次打印之間沒有對b進(jìn)行任何操作,那么b為什么會發(fā)生變化,問題肯定是出在了append方法上。
通過一系列的資料查詢,發(fā)現(xiàn)append方法是淺拷貝方法,什么是淺拷貝呢?
官方一點的解釋就是:
在Python中,對象賦值實際上是對象的引用,當(dāng)創(chuàng)建一個對象,然后把它賦值給另一個變量的時候,Python并沒有拷貝這個對象,而只是拷貝了這個對象的引用,這就是淺拷貝。
什么,你說你還沒懂淺拷貝?沒關(guān)系,下面還有:
a = 1
b = 1
print(id(a))
print(id(b))
# 此時你會發(fā)現(xiàn),a和b在內(nèi)存中的地址居然是一樣的
?因為在Python中,先是生成了對象,然后才是變量對對象的引用。比如,1是一個對象,然后a和b再分別對1進(jìn)行引用,由于常數(shù)是不可變類型,所以1的內(nèi)存空間是一樣的,所以a和b共用一塊內(nèi)存空間。
?形象的來解釋就是:
有一個盒子,盒子里面放著1,然后a和b對1進(jìn)行引用的時候就是直接把a和b的標(biāo)簽貼到這個盒子上。
回歸正題:
a = [1,2]
b = []
b.append(a)
print(b)
a.append(3)
print(b)
# 開始時a這個盒子等于[1,2],b這個盒子等于[]
# 使用b.append(a)相當(dāng)于將盒子a放入盒子b中
# 所以再使用a.append(3)的時候,b也會跟著一起改變呀!!!
Python列表的append函數(shù)
append的功能
將一個元素添加到當(dāng)前列表中
append的用法
用法:list.append(new_item)
參數(shù):new_item:添加進(jìn)列表的新的元素(成員)
In [19]: names = ['insane']
In [20]: names.append('loafer')
In [21]: print(names)
['insane', 'loafer']
append的注意事項
- 被添加的元素只會被添加到末尾變量
- append函數(shù)是在原有列表的基礎(chǔ)上添加,不需要額外添加新的變量
實戰(zhàn)
每次只能添加一個變量
# coding:utf-8
books = []
print(id(books))
books.append('python')
print(books)
print(id(books))
number = 1.1
tuple_test = (1,)
dict_test = {'name': 'insane'}
books.append(number) # 每次只能加入一個變量
books.append(tuple_test)
books.append(dict_test)
print(books)
books.append('django')
books.append(1)
print(books)
print(id(books))
2029563540224
['python']
2029563540224
['python', 1.1, (1,), {'name': 'insane'}]
['python', 1.1, (1,), {'name': 'insane'}, 'django', 1]
2029563540224Process finished with exit code 0
原文鏈接:https://blog.csdn.net/weixin_42788769/article/details/119215237
相關(guān)推薦
- 2023-07-24 利用keyup事件實現(xiàn)input框輸入0-1之間的數(shù)字且最多只能保留2位小數(shù)
- 2022-09-07 Python的flask常用函數(shù)route()_python
- 2022-05-06 C語言中回調(diào)函數(shù)的使用詳情_C 語言
- 2024-03-17 針對Tomcat部署項目,修改后臺代碼,前臺網(wǎng)頁無變化問題的解決方案(超詳細(xì)有效)
- 2022-05-08 C#使用Unity實現(xiàn)IOC_實用技巧
- 2022-06-21 Android實現(xiàn)登陸界面的記住密碼功能_Android
- 2022-07-12 快速上手Vim編輯器
- 2023-05-15 使用Bash讀取和處理CSV文件的方法_linux shell
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支