初學(xué)golang,在看到使用sort.SearchInts時(shí),自己實(shí)踐發(fā)現(xiàn)當(dāng)這個(gè)函數(shù)在目標(biāo)slice中搜索不到被搜索元素時(shí)竟然返回了被搜索的元素應(yīng)該在目標(biāo)slice中按升序排序該插入的位置這讓我感到十分不解也很不舒服,如果我想知道目標(biāo)slice中有沒有這個(gè)元素,我還得判斷一下目標(biāo)slice中返回值這個(gè)位置到底是不是我正在搜索的這個(gè)元素??一般來說其他語言都會返回-1 以表示要搜索的slice中沒有這個(gè)元素,golang這么做到底有何用意呢? 例子如下:package mainimport ( "fmt"
"sort")func main() { var a = []int{1, 2, 3, 1, 5, 9,11,859,316,83,168,462} if !sort.IntsAreSorted(a) {
sort.Ints(a)
fmt.Printf("%v\n", a) var index = sort.SearchInts(a, 66)
fmt.Printf("%d\n", index)
} var s = []string{"啊", "中", "我", "n", "1", "a", "2", "你"} if !sort.StringsAreSorted(s) {
sort.Strings(s)
fmt.Printf("%v\n", s)
fmt.Printf("%d\n", sort.SearchStrings(s, "z"))
}
}運(yùn)行結(jié)果:[1 1 2 3 5 9 11 83 168 316 462 859]7[1 2 a n 中 你 啊 我]4
golang內(nèi)置的sort.SearchXxxx在搜索不到時(shí)的返回值有何特殊用意?
翻閱古今
2019-03-15 18:21:20