網站首頁 編程語言 正文
淺析golang切片截取(刪除)功能
1. 引言
golang的切片被認為是和C++的vector容器類似,都可以認為是動態數組,但又不完全一樣。
那么區別到底在哪里呢?對元素的刪除方式是很重要的一點區別
- 對于C++的vector來說,用erase函數來刪除元素,其原理是將當前位置后面的元素都向前移動一位,刪除一個元素的平均時間復雜度為O(n)
- 對于golang的slice來說,沒有用來刪除元素的函數,但是其可以通過改變指向底層數組的指針和append的方式巧妙的實現元素的刪除,對頭部元素和尾部元素刪除時間復雜度都為O(1),所以可以用切片來模擬棧和隊列,而C++用vector模擬隊列的時間復雜度過高,C++隊列的底層是deque,下文將利用代碼進行具體分析
2.分析過程
2.1 s[:]的方式截取元素
可以利用s[1:]的方式來刪除切片的第一個元素,產生的新切片仍舊與原切片共用一個底層數組,只是將底層數組的指針向后移動了一位。所以修改s2的元素,s1的元素也會改變。這一點是和vector最不同的,slice刪除頭部元素只需要O(1)的時間復雜度
func main() { // 驗證切片的截取功能 s1 := []int{1,2,3,4,5} s2 := s1[1:] fmt.Println("切片s1:",s1) fmt.Println("切片s2:",s2) s2[0] = 6 fmt.Println("修改s2的第一個元素后,切片s1:",s1) fmt.Println("修改s2的第一個元素后,切片s2:",s2) }
上面這段代碼的輸出結果為:
2.2 append的方式截取元素
用append截取s1得到s3。append截取的方式類似于erase,后面的元素會向前移動。但是由于s3和s2,s1共用一個底層數組,截取得到s3時,s1,s2的元素也會改變。對于中間元素的刪除slice和vector時間復雜度相同
func main() { // 驗證切片的截取功能 s1 := []int{1,2,3,4,5} s2 := s1[1:] s3 := append(s1[0:2],s1[3:]...) fmt.Println("切片s1:",s1) fmt.Println("切片s2:",s2) fmt.Println("切片s3:",s3) s2[0] = 6 fmt.Println("修改s2的第一個元素后,切片s1:",s1) fmt.Println("修改s2的第一個元素后,切片s2:",s2) fmt.Println("修改s2的第一個元素后,切片s3:",s3) }
輸出結果為:
3. 結論
正是由于slice可以方便的刪除頭部元素和尾部元素,所以用其模擬棧和隊列。而vector對于頭部元素的刪除復雜度太高,所以不建議用vector實現隊列
原文鏈接:https://blog.csdn.net/qq_42290165/article/details/127180662
相關推薦
- 2022-02-02 使用layui框架時,select的onchange事件沒有生效。
- 2023-02-12 python中使用docx模塊處理word文檔_python
- 2024-03-24 feignClient注入失敗
- 2022-05-22 查看Docker容器的信息的方法實現_docker
- 2023-12-14 excel統計某個字符出現的次數,判斷某單元格的數據是否在另外一列
- 2022-08-20 Pygame?精準檢測圖像碰撞的問題_python
- 2024-01-07 @Modifying注解和@Transactional注解?
- 2022-10-27 Kotlin協程之Flow基礎原理示例解析_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支