package main
import (
"fmt"
"strings"
)
func Index(vs []string, t string) int {
for i, v := range vs {
if v == t {
return i
}
}
return -1
}
func Includes(vs []string, t string) bool {
return Index(vs, t) >= 0
}
func Some(vs []string, f func(string) bool) bool {
for _, v := range vs {
if f(v) {
return true
}
}
return false
}
func Every(vs []string, f func(string) bool) bool {
for _, v := range vs {
if !f(v) {
return false
}
}
return true
}
func Filter(vs []string, f func(string) bool) []string {
vsf := make([]string, 0)
for _, v := range vs {
if f(v) {
vsf = append(vsf, v)
}
}
return vsf
}
func Map(vs []string, f func(string) string) []string {
vsm := make([]string, len(vs))
for i, v := range vs {
vsm[i] = f(v)
}
return vsm
}
func main() {
strs := []string{"peach", "apple", "pear", "plum"}
fmt.Println(Index(strs, "pear"))
fmt.Println(Includes(strs, "gpear"))
s := Some(strs, func(s string) bool {
return strings.HasPrefix(s, "p")
})
fmt.Println(s)
e := Every(strs, func(s string) bool {
return strings.HasPrefix(s, "p")
})
fmt.Println(e)
f := Filter(strs, func(s string) bool {
return strings.Contains(s, "e")
})
fmt.Println(f)
m := Map(strs, strings.ToUpper)
fmt.Println(m)
}
go-基础-切片函数
最新推荐文章于 2024-05-23 19:06:15 发布