Sebagai pembangun Java yang lama, saya terobsesi dengan semakan nol dan mengendalikan nilai nol. Di golang, ceritanya lain sikit. Dalam post ini, saya akan cuba menerangkan cara menggunakan nil
dan 零值
dalam golang.
Jenis In go boleh kosong atau bukan nol. Jenis bukan nol tidak boleh menjadi nil, dan tidak akan menyebabkan anda menyebabkan nil-panic
(bersamaan dengan nullpointerexception Java Walaupun tidak sebanyak dalam java (atau bahasa lain dengan jenis null), apabila berurusan dengan null jenis, Kita masih perlu sedikit berhati-hati.
Jenis asas bukan nol
Seterusnya, jenis asas tidak boleh batal. Pengisytiharan seperti
var a int = nil
gagal disusun kerana int
tidak boleh menjadi nil Nilai lalai untuk jenis int
yang tidak ditetapkan ialah 0.
Jalankan pernyataan
var a int // int类型的默认值不能为nil fmt.Println(a) // 0
"int
". dengan nilai sifar Jenis asas:0
Non-nillable structs
组合的struct
类型也是不可空的,并且struct的默认值将包含其所有字段的默认值。
设定一个 Person 结构体的代码,
type Person struct { Name string Age int } var p Person // person 类型的默认 0 值 fmt.Printf("[%#v]\n", p)
当你在 main 方法里运行这段代码的时候,将会打印出 [main.Person{Name:"", Age:0}]
你可以在 Go Playground 上运行这段代码进行测试。
nillable 类型
还有一种更高级到 nillable 类型,如果对应的类型未初始化,将会报错,触发 panic 。
这些可以为 nillabel 类型的 函数,通道,切片,map,接口以及指针.
但是,nil-slice 和nil-maps 仍然可以使用,在我们开始使用它们之前不必进行初始化。
nil-maps
如果 map 的值为 nil,map 将始终返回值的零值,与返回不存在 map 中的 Key 的结果一样。代码
var p map[int]string // nil map fmt.Printf(" %#v length %d \n", p[99], len(p))
让我们来打印下 "" length 0
, 我们可以获得键为99的字符串string
的值为零.
将值分配给 nil-map, 会引起死机状况的出现:
var p map[string]int // nil map p["nils"] = 19 // panic: 对nil-map中的条目赋值
nil-slices
在外部引用切片 will 将导致死机,但是 len()
和 cap()
的操作不会导致死机出现. 他们只返回 0
, 因为对于未初始化的切片,其容量和长度都为零. 所以他们可以在nil-slice上成功调用append. 示例代码如下:
var p []string // nil slice fmt.Printf("uninitialized -> %d, %d\n", len(p), cap(p)) p1 := append(p, "nils") // 从P创建一个新的切片p1 fmt.Printf("after append -> %d, %d %#v\n", len(p1), cap(p1), p1)
会打印:
uninitialized -> 0, 0 after append -> 1, 1 []string{"nils"}
在 Go Playground 上试验。
可为 nil 值的指针、函数和接口类型会引起 panic
Pointers and interface-types are however nillable. Whenever dealing with these types, we have to consider if they are nil or not to avoid panics. These code-snippets for instance, will cause a panic:
指针和接口类型是可为 nil 值的。每当处理这些类型时,我们都必须考虑它们是否为零,以免出现 Panic。例如,这些代码片段将引起 Panic:
var p *int // 指向 int 的指针 *p++ // panic: runtime error: invalid memory address or nil pointer dereference // p是无内容的地址,因此为nil
和
var p error // 类型 error 的 nil 值 error.Error() // panic: runtime error: invalid memory address or nil pointer dereference
和
var f func(string) // nil 函数 f("oh oh") // panic: runtime error: invalid memory address or nil pointer dereference
nil channel 永远阻塞
尝试从 nil 通道读取或写入 nil 通道将永远受阻。关闭nil通道会引起 Panic 。
nil
在go中有很好的定义。知道什么可以是 nil 以及如何处理不同类型的 nil 值可以增加您对发生的事情的理解,并且可以帮助您编写更好的 go 代码。
原文地址:https://nilsmagnus.github.io/post/nillability-in-go/
译文地址:https://learnku.com/go/t/46496
Atas ialah kandungan terperinci Analisis ringkas nilai sifar dan sifar di Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!