
在 go 语言中,可通过直接赋值将一个固定长度的字符串数组完整复制到另一个同类型数组中,但要求两个数组长度必须严格一致;若长度不同,编译器将报错。
在 go 语言中,可通过直接赋值将一个固定长度的字符串数组完整复制到另一个同类型数组中,但要求两个数组长度必须严格一致;若长度不同,编译器将报错。
Go 中的数组是值类型,这意味着数组变量本身包含所有元素的数据,而非指向底层数组的引用。因此,当使用 = 对两个同类型数组进行赋值时,Go 会执行一次完整的、按元素逐个拷贝的深复制(deep copy),新数组与原数组完全独立,修改任一数组不会影响另一个。
✅ 正确做法:同长度数组间的直接赋值
以下示例展示了如何安全地将一个字符串数组复制到另一个同长度数组:
package main
import "fmt"
func main() {
// 原数组:长度为 5 的字符串数组
array2 := [5]string{"A", "B", "C", "D", "E"}
// 目标数组:声明为相同长度(5)的空数组
var array1 [5]string
// ✅ 合法赋值:类型和长度完全匹配
array1 = array2
fmt.Println("array1:", array1) // [A B C D E]
fmt.Println("array2:", array2) // [A B C D E]
// 修改 array1 不会影响 array2
array1[0] = "X"
fmt.Println("after change array1[0]:")
fmt.Println("array1:", array1) // [X B C D E]
fmt.Println("array2:", array2) // [A B C D E]
}❌ 常见错误:长度不匹配导致编译失败
Go 对数组类型检查极为严格——[4]string 和 [5]string 是完全不同的类型,不可相互赋值:
var array1 [4]string
array2 := [5]string{"A", "B", "C", "D", "E"}
array1 = array2 // ❌ 编译错误:
// cannot use array2 (type [5]string) as type [4]string in assignment该错误发生在编译期,无法绕过。若需处理动态长度或灵活拷贝,应考虑改用切片([]string)并配合 copy() 函数或 append()。
? 补充:若需“类数组”弹性拷贝,推荐使用切片
虽然本题聚焦于数组,但在实际开发中,更常用且灵活的是切片。如需兼容不同长度或运行时确定容量,可参考如下惯用法:
src := []string{"A", "B", "C", "D", "E"}
dst := make([]string, len(src))
copy(dst, src) // 安全、高效、长度自适应? 总结要点
- ✅ 数组赋值即深拷贝,语义清晰、线程安全;
- ✅ 必须确保源数组与目标数组的类型完全一致(含元素类型与长度);
- ❌ 长度不同的数组不可赋值,无隐式转换;
- ? 若业务逻辑涉及可变长度、动态扩容或函数间传递,优先选用切片而非数组;
- ⚠️ 注意内存开销:大数组(如 [10000]string)赋值会产生显著拷贝成本,此时应评估是否真需值语义,或改用指针传递 *[N]string。
掌握数组赋值的本质,有助于写出更安全、更符合 Go 类型哲学的代码。










