網站首頁 編程語言 正文
結構圖:
為什么?
var data [][]int for _, rangeSlice := range [][]int{{1}, {2}, {3}} { data = append(data, rangeSlice[:]) } fmt.Printf("%v", data) // 輸出 [[1] [2] [3]]
var data [][]int for _, rangeArray := range [][1]int{{1}, {2}, {3}} { data = append(data, rangeArray[:]) } fmt.Printf("%v", data) // 輸出 [[3] [3] [3]]
理解
for key, value := range container{ // loop }
在?for range
?語法中,value
?是?for range
?循環返回元素的值的拷貝。
case rangeSlice
var data [][]int for _, rangeSlice := range [][]int{{1}, {2}, {3}} { data = append(data, rangeSlice[:]) } fmt.Printf("%v", data) // 輸出 [[1] [2] [3]]
代碼中,rangeSlice
?是切片?[]int{1}
?or?[]int{2}
?or?[]int{3}
?的一個拷貝,底層是數組?[1]int{1}
?or?[1]int{2}
?or?[1]int{3}
,所以在?rangeSlice
?的切片?append
?到?data
?后,data
?的元素也是這幾個底層數組的切片,所以上述代碼片段的輸出為?[[1] [2] [3]]
。
case rangeArray
var data [][]int for _, rangeArray := range [][1]int{{1}, {2}, {3}} { data = append(data, rangeArray[:]) } fmt.Printf("%v", data) // 輸出 [[3] [3] [3]]
代碼中,rangeArray
?是數組?[1]int{1}
?or?[1]int{2}
?or?[1]int{3}
?的一個拷貝,在每次循環中,rangeArray
?用的都是同一個數組內存空間,所以在?rangeArray
?這個數組的切片?append
?到?data
?后,data
?的元素都是指向同一底層數組的切片,在循環的最后一輪?rangeArray
?為?[1]int{3}
,所以上述代碼片段的輸出為?[[3] [3] [3]]
。
測試代碼
package main import "fmt" func rangeSlice() { source := [][]int{{1}, {2}, {3}} var data [][]int for idx, rangeSlice := range source { fmt.Printf("%T %p %T %p", rangeSlice, rangeSlice, source[idx], source[idx]) fmt.Printf(" append slice %p\n", rangeSlice[:]) data = append(data, rangeSlice[:]) } fmt.Printf("data: %v\n", data) } func rangeArray() { source := [][1]int{{1}, {2}, {3}} var data [][]int for idx, rangeArray := range source { fmt.Printf("%T %p %T %p", rangeArray, &rangeArray, source[idx], &source[idx]) fmt.Printf(" append slice %p\n", rangeArray[:]) data = append(data, rangeArray[:]) } fmt.Printf("data: %v\n", data) } func main() { rangeSlice() rangeArray() } // 輸出: // []int 0xc00001a0a8 []int 0xc00001a0a8 append slice 0xc00001a0a8 // []int 0xc00001a0b0 []int 0xc00001a0b0 append slice 0xc00001a0b0 // []int 0xc00001a0b8 []int 0xc00001a0b8 append slice 0xc00001a0b8 // data: [[1] [2] [3]] // [1]int 0xc00001a0e0 [1]int 0xc0000160f0 append slice 0xc00001a0e0 // [1]int 0xc00001a0e0 [1]int 0xc0000160f8 append slice 0xc00001a0e0 // [1]int 0xc00001a0e0 [1]int 0xc000016100 append slice 0xc00001a0e0 // data: [[3] [3] [3]]
原文鏈接:https://juejin.cn/post/7120078796845219871
相關推薦
- 2022-04-16 C#基于Socket實現多人聊天功能_C#教程
- 2022-01-21 面試題:說一說es6新增方法
- 2022-08-20 swift?framework使用OC?代碼兩種方式示例_Swift
- 2024-02-26 啟動zabbix服務報“./zabbix_agentd: cannot execute binary
- 2022-07-11 Python利用xlrd?與?xlwt?模塊操作?Excel_python
- 2022-10-24 C++??STL?_?Vector使用及模擬實現_C 語言
- 2022-07-08 Python如何通過地址獲取變量_python
- 2022-06-18 C#使用ThreadPriority設置線程優先級_C#教程
- 最近更新
-
- 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同步修改后的遠程分支