golang中strings包函数示例

本文介绍了一系列Go语言中字符串处理函数的使用示例,包括比较、查找、替换等常见操作,帮助开发者更好地理解和运用这些工具。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

func Compare(a, b string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Compare("123","123"))
    fmt.Println(strings.Compare("123","456"))
    fmt.Println(strings.Compare("456","123"))
}

func Contains(s, substr string) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Contains("seafood", "foo"))
    fmt.Println(strings.Contains("seafood", "bar"))
    fmt.Println(strings.Contains("seafood", ""))
    fmt.Println(strings.Contains("", ""))
}

func ContainsAny(s, chars string) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.ContainsAny("team", "i"))
    fmt.Println(strings.ContainsAny("failure", "u & i"))
    fmt.Println(strings.ContainsAny("foo", ""))
    fmt.Println(strings.ContainsAny("", ""))
}

func ContainsRune(s string, r rune) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    s := "我爱你"
    r := rune('我')
    fmt.Println(strings.ContainsRune(s, r))
}

func Count(s, sep string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Count("cheese", "e"))
    fmt.Println(strings.Count("five", "")) // before & after each rune
}

func EqualFold(s, t string) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.EqualFold("Go", "go"))
}

func Fields(s string) []string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("Fields are: %q", strings.Fields("  foo bar  baz   "))
}

func FieldsFunc(s string, f func(rune) bool) []string

package main

import (
    "fmt"
    "strings"
    "unicode"
)

func main() {
    f := func(c rune) bool {
        return !unicode.IsLetter(c) && !unicode.IsNumber(c)
    }
    fmt.Printf("Fields are: %q", strings.FieldsFunc("  foo1;bar2,baz3...", f))
}

func HasPrefix(s, prefix string) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.HasPrefix("Gopher", "Go"))
    fmt.Println(strings.HasPrefix("Gopher", "C"))
    fmt.Println(strings.HasPrefix("Gopher", ""))
}

func HasSuffix(s, suffix string) bool

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.HasSuffix("Amigo", "go"))
    fmt.Println(strings.HasSuffix("Amigo", "O"))
    fmt.Println(strings.HasSuffix("Amigo", "Ami"))
    fmt.Println(strings.HasSuffix("Amigo", ""))
}

func Index(s, sep string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Index("chicken", "ken"))
    fmt.Println(strings.Index("chicken", "dmr"))
}

func IndexAny(s, chars string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.IndexAny("chicken", "aeiouy"))
    fmt.Println(strings.IndexAny("crwth", "aeiouy"))
}

func IndexByte(s string, c byte) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.IndexByte("a chicken", 0x63))//index 'c'
}

func IndexFunc(s string, f func(rune) bool) int

package main

import (
    "fmt"
    "strings"
    "unicode"
)

func main() {
    f := func(c rune) bool {
        return unicode.Is(unicode.Han, c)
    }
    fmt.Println(strings.IndexFunc("Hello, 世界", f))
    fmt.Println(strings.IndexFunc("Hello, world", f))
}

func IndexRune(s string, r rune) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.IndexRune("chicken", 'k'))
    fmt.Println(strings.IndexRune("chicken", 'd'))
}

func Join(a []string, sep string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    s := []string{"foo", "bar", "baz"}
    fmt.Println(strings.Join(s, ", "))
}

func LastIndex(s, sep string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Index("go gopher", "go"))
    fmt.Println(strings.LastIndex("go gopher", "go"))
    fmt.Println(strings.LastIndex("go gopher", "rodent"))
}

func LastIndexAny(s, chars string) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.LastIndexAny("go gopher", "go"))
    fmt.Println(strings.LastIndexAny("go gopher", "rodent"))
}

func LastIndexByte(s string, c byte) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.LastIndexByte("a chicken", 0x63))
}

func LastIndexFunc(s string, f func(rune) bool) int

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.LastIndexFunc("我爱go语言我", func(r rune) bool{
        if r == '我'{
            return true
        }
        return false
    }) )
}

func Map(mapping func(rune) rune, s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    rot13 := func(r rune) rune {
        switch {
        case r >= 'A' && r <= 'Z':
            return 'A' + (r-'A'+13)%26
        case r >= 'a' && r <= 'z':
            return 'a' + (r-'a'+13)%26
        }
        return r
    }
    fmt.Println(strings.Map(rot13, "'Twas brillig and the slithy gopher..."))
}

func Repeat(s string, count int) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println("ba" + strings.Repeat("na", 2))
}

func Replace(s, old, new string, n int) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Replace("oink oink oink", "k", "ky", 2))
    fmt.Println(strings.Replace("oink oink oink", "oink", "moo", -1))
}

func Split(s, sep string) []string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("%q\n", strings.Split("a,b,c", ","))
    fmt.Printf("%q\n", strings.Split("a man a plan a canal panama", "a "))
    fmt.Printf("%q\n", strings.Split(" xyz ", ""))
    fmt.Printf("%q\n", strings.Split("", "Bernardo O'Higgins"))
}

func SplitAfter(s, sep string) []string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("%q\n", strings.SplitAfter("a,b,c", ","))
}

func SplitAfterN(s, sep string, n int) []string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("%q\n", strings.SplitAfterN("a,b,c", ",", 2))
}

func SplitN(s, sep string, n int) []string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("%q\n", strings.SplitN("a,b,c", ",", 2))
    z := strings.SplitN("a,b,c", ",", 0)
    fmt.Printf("%q (nil = %v)\n", z, z == nil)
}

func Title(s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.Title("her royal highness"))
}

func ToLower(s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.ToLower("Gopher"))
}

func ToLowerSpecial(_case unicode.SpecialCase, s string) string

package main

import (
    "fmt"
    "strings"
    "unicode"
)

func main() {
    var sc unicode.SpecialCase
    fmt.Println(strings.ToLowerSpecial(sc, "Hello Gopher"))
}

func ToTitle(s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.ToTitle("loud noises"))
    fmt.Println(strings.ToTitle("хлеб"))
}

func ToTitleSpecial(_case unicode.SpecialCase, s string) string

package main

import (
    "fmt"
    "strings"
    "unicode"
)

func main() {
    var sc unicode.SpecialCase
    fmt.Println(strings.ToTitleSpecial(sc, "Hello Gopher"))
}

func ToUpper(s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.ToUpper("Gopher"))
}

func ToUpperSpecial(_case unicode.SpecialCase, s string) string

package main

import (
    "fmt"
    "strings"
    "unicode"
)

func main() {
    var sc unicode.SpecialCase
    fmt.Println(strings.ToUpperSpecial(sc, "Hello Gopher"))
}

func Trim(s string, cutset string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("[%q]", strings.Trim(" !!! Achtung! Achtung! !!! ", "! "))
}

func TrimFunc(s string, f func(rune) bool) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.TrimFunc("我爱go语言我", func(r rune) bool{
        if r == '我'{
            return true
        }
        return false
    }) )
}

func TrimLeft(s string, cutset string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("[%q]", strings.TrimLeft(" a!!! Achtung! Achtung! !!! ", "a !"))
}

func TrimLeftFunc(s string, f func(rune) bool) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.TrimLeftFunc("我爱go语言我", func(r rune) bool{
        if r == '我'{
            return true
        }
        return false
    }) )
}

func TrimPrefix(s, prefix string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    var s = "Goodbye,, world!"
    s = strings.TrimPrefix(s, "Goodbye,")
    s = strings.TrimPrefix(s, "Howdy,")
    fmt.Print("Hello" + s)
}

func TrimRight(s string, cutset string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Printf("[%q]", strings.TrimRight(" a!!! Achtung! Achtung! !!! ", "a !"))
}

func TrimRightFunc(s string, f func(rune) bool) string

1

func TrimSpace(s string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(strings.TrimSpace(" \t\n a lone gopher \n\t\r\n"))
}

func TrimSuffix(s, suffix string) string

package main

import (
    "fmt"
    "strings"
)

func main() {
    var s = "Hello, goodbye, etc!"
    s = strings.TrimSuffix(s, "goodbye, etc!")
    s = strings.TrimSuffix(s, "planet")
    fmt.Print(s, "world!")
}
<think>好的,用户现在想了解Go语言中的可变参数函数。之前他们问过如何将数组转换成JSON文件,现在转向了另一个基础但重要的主题。我需要先确认自己对可变参数函数的理解是否正确,然后组织一个清晰的回答。 首先,可变参数函数在Go中是通过在参数类型前加...来定义的,允许函数接受任意数量的该类型参数。这个特性在处理不定数量参数时非常有用,比如fmt.Println。需要明确的是,可变参数在函数内部会被当作切片来处理,所以可以像操作切片一样操作它们。 接下来,用户可能的疑问点:比如可变参数的类型限制,是否只能同一种类型,是否可以有其他参数,以及如何传递切片给可变参数。这些都需要在回答中覆盖到。另外,可能需要举例说明如何定义和使用,以及注意事项,比如可变参数必须放在参数列表的最后。 用户可能是一个刚开始学习Go的开发者,已经了解了一些基本语法和结构体、JSON处理,现在想深入函数的使用。他们可能在实际编码中遇到了需要处理不同数量参数的情况,比如日志函数、聚合计算等,所以需要知道如何利用可变参数来简化代码。 需要确保回答结构清晰,步骤明确,示例代码简洁易懂。同时,应该指出常见错误或注意事项,比如传递不同类型的参数会导致错误,或者如何正确传递切片。可能还需要比较Go的可变参数与其他语言(如Python)的不同之处,以帮助用户更好地理解。 最后,总结关键点,帮助用户回顾主要内容。确保语言口语化,避免过于技术化的术语,但保持准确性。检查示例代码是否有错误,比如是否正确使用...语法,以及是否处理了可能的错误情况。</think>在 Go 语言中,**可变参数函数(Variadic Function)** 是指可以接受**不定数量参数**的特殊函数。通过 `...` 语法实现,常用于处理数量不定的输入场景(如日志记录、聚合计算等)。以下是详细说明和示例: --- ### 一、基础语法 在参数类型前添加 `...` 表示可变参数,**该参数会被转换为切片**: ```go func 函数名(固定参数, 可变参数名 ...类型) 返回值 { // 函数体(可变参数会被视为切片) } ``` --- ### 二、使用示例 #### 示例 1:基本数值求和 ```go func sum(nums ...int) int { total := 0 for _, num := range nums { total += num } return total } func main() { fmt.Println(sum(1, 2, 3)) // 输出 6 fmt.Println(sum(10, 20, 30, 40)) // 输出 100 } ``` #### 示例 2:混合固定参数与可变参数 ```go func joinStrings(sep string, strs ...string) string { return strings.Join(strs, sep) } func main() { fmt.Println(joinStrings("-", "Go", "Python", "Java")) // 输出 Go-Python-Java } ``` --- ### 三、关键特性 1. **切片传递机制** 可变参数在函数内部实际上是一个**切片**,可通过 `len` 和索引访问: ```go func printNames(names ...string) { fmt.Println("切片长度:", len(names)) for i, name := range names { fmt.Printf("索引 %d: %s\n", i, name) } } ``` 2. **直接传递切片** 若已有切片,可通过 `切片名...` 语法展开传递: ```go numbers := []int{5, 10, 15} fmt.Println(sum(numbers...)) // 输出 30 ``` 3. **空参数处理** 不传递可变参数时,函数会收到一个**空切片**而非 `nil`: ```go func checkEmpty(args ...int) { fmt.Println(args == nil) // 输出 false fmt.Println(len(args)) // 输出 0 } ``` --- ### 四、注意事项 1. **类型一致性** 可变参数必须为**同一类型**,混合类型会导致编译错误: ```go // 错误示例:参数类型不统一 sum(1, 2.5) // 编译失败(int 与 float64 不匹配) ``` 2. **参数位置限制** 可变参数必须位于参数列表的**最后**: ```go // 正确示例 func example(a int, b ...string) {} // 错误示例 func errorExample(a ...int, b string) {} ``` 3. **空接口的灵活使用** 结合 `interface{}` 可实现任意类型参数(需类型断言处理): ```go func printAll(values ...interface{}) { for _, v := range values { switch v.(type) { case int: fmt.Println("整数:", v) case string: fmt.Println("字符串:", v) } } } func main() { printAll(10, "Hello", 3.14) // 注意:3.14 是 float64 类型,需额外处理 } ``` --- ### 五、适用场景 - 日志函数(如 `fmt.Printf`) - 聚合计算(求和、求平均值等) - 批量数据操作(批量插入、批量查询) - 工具函数(字符串拼接、切片合并) --- ### 六、与其他语言的对比 | 特性 | Go | Python | |--------------------|-----------------------------|----------------------| | 语法 | `func foo(args ...Type)` | `def foo(*args)` | | 参数类型 | 必须相同 | 允许不同 | | 空参数行为 | 空切片(非 `nil`) | 空元组 | | 展开已有集合 | `slice...` | `*list` | --- 通过可变参数函数,可以显著提升代码的灵活性和简洁性,但需注意类型安全性和参数位置限制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值