golang 泛型 lo

go 1.18之后,go语言做出重大更新:支持泛型。这极大地缩减了代码冗余量,但是同时也降低了代码可读性。

它包含了slice、map、tuples等辅助函数,还提供了多个集合之间计算辅助方法,甚至一些搜索查询辅助方法。

string

1. 生成随机字符串

生成指定长度、指定范围的随机字符串

 ### 字符范围
var (
	LowerCaseLettersCharset = []rune("abcdefghijklmnopqrstuvwxyz")  // 小写英文字母
	UpperCaseLettersCharset = []rune("ABCDEFGHIJKLMNOPQRSTUVWXYZ")  // 大写英文字母
	LettersCharset          = append(LowerCaseLettersCharset, UpperCaseLettersCharset...)  // 大、小写英文字母
	NumbersCharset          = []rune("0123456789")  // 阿拉伯数字
	AlphanumericCharset     = append(LettersCharset, NumbersCharset...)  // 数字 + 英文字母
	SpecialCharset          = []rune("!@#$%^&*()_+-=[]{}|;':\",./<>?")   // 特殊字符
	AllCharset              = append(AlphanumericCharset, SpecialCharset...)  // 所有字符
)

package main

import (
	"fmt"

	"github.com/samber/lo"
)

func main() {
	result := lo.RandomString(5, lo.LettersCharset)

	fmt.Printf("%v", result)
}

----------
输出:disAD

子串

返回字符串的指定位置、指定长度的子串。

package main

import (
	"fmt"
	"math"

	"github.com/samber/lo"
)

func main() {
	result1 := lo.Substring("hello", 2, 3)
	result2 := lo.Substring("hello", -4, 3)
	result3 := lo.Substring("hello", -2, math.MaxUint)

	fmt.Printf("%v\n", result1)
	fmt.Printf("%v\n", result2)
	fmt.Printf("%v\n", result3)
}

----------
输出:
llo
ell
lo

字符串长度

返回字符串包含的字符的单位的个数(中文汉字、英文字母、表情都算一个字符单位)

package main

import (
	"fmt"

	"github.com/samber/lo"
)

func main() {
	result1, chars1 := lo.RuneLength("hellô"), len("hellô")
	result2, chars2 := lo.RuneLength("🤘"), len("🤘")

	fmt.Printf("%v %v\n", result1, chars1)
	fmt.Printf("%v %v\n", result2, chars2)
}

----------
输出:
5 6
1 4

slice

1. 过滤

package main

import (
	"fmt"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	result := lo.Filter(list, func(nbr int64, index int) bool {
		return nbr%2 == 0  // 过滤条件
	})

	fmt.Printf("%v", result)
} 

----------
输出:[2 4]

2. 映射

切片中的每个元素按照映射关系可以映射成新的元素。

package main

import (
	"fmt"
	"strconv"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	result := lo.Map(list, func(nbr int64, index int) string {
		return strconv.FormatInt(nbr*2, 10)
	})

	fmt.Printf("%v", result)
} 

----------
输出:[2 4 6 8]

3. 映射并过滤 (1. 和2. 的结合)

package main

import (
	"fmt"
	"strconv"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	result := lo.FilterMap(list, func(nbr int64, index int) (string, bool) {
		return strconv.FormatInt(nbr*2, 10), nbr%2 == 0
	})

	fmt.Printf("%v", result)
}

----------
[4 8]

4. 多维映射并展平

切片中每个元素可映射成多个元素,并将其展平成一维切片。

package main

import (
	"fmt"
	"strconv"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	result := lo.FlatMap(list, func(nbr int64, index int) []string {
		return []string{
			strconv.FormatInt(nbr, 10), // base 10
			strconv.FormatInt(nbr, 2),  // base 2
		}
	})

	fmt.Printf("%v", result)
} 

----------
输出:[1 1 2 10 3 11 4 100]

5. 累加器

agg维持累加结果,item是切片的每个元素。

package main

import (
	"fmt"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	result := lo.Reduce(list, func(agg int64, item int64, index int) int64 {
		return agg * item
	}, 1)   // 1: 累加器的初始值

	fmt.Printf("%v", result)
}
 

6. 迭代器

package main

import (
	"fmt"

	"github.com/samber/lo"
)

func main() {
	list := []int64{1, 2, 3, 4}

	lo.ForEach(list, func(x int64, _ int) {
		fmt.Println(x)
	})
} 

----------
输出:
1
2
3
4

未完待续。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Golang中,泛型接口是一种接口类型,可以用于处理不同类型的数据。泛型接口在编程中非常有用,因为它允许我们编写可重用、灵活的代码,而无需针对特定类型进行硬编码。 在Golang中,泛型接口可以通过使用空接口(`interface{}`)来实现。空接口是一个没有任何方法的接口,可以接受任何类型的值。通过使用空接口,可以实现泛型的功能,使得接口可以接收任何类型的数据。 使用泛型接口,我们可以在不改变接口定义的情况下,接受不同类型的参数。例如,我们可以定义一个泛型接口`Container`,用于表示一个可以容纳不同类型元素的容器。这个接口可以定义添加元素、删除元素以及获取元素等方法。 使用泛型接口的好处是可以编写灵活的代码,尽可能减少重复代码的编写。由于泛型接口可以处理多种类型的数据,我们可以将相同的逻辑应用于不同的数据类型,实现代码的重用。 然而,目前Golang没有原生支持泛型接口的功能,因此在实现泛型接口时可能需要一些额外的代码处理。一种常见的做法是使用类型断言来判断接口的实际类型,然后进行相应的操作。 总而言之,虽然Golang没有内置的泛型功能,但通过使用空接口和类型断言,我们可以实现泛型接口从而处理不同类型的数据,提高代码的重用性和灵活性。 ### 回答2: Go语言是一种静态类型的编程语言,其最近的版本Go 1.18中引入了泛型接口的概念。泛型指的是在编写代码时不指定具体类型,而是允许使用者在使用时根据自己的需求来指定具体的类型。 在传统的面向对象编程中,常用的接口表示方式是通过接口类型断言来判断对象是否实现了某个接口。但是这种方式在处理不同类型的数据时需要进行类型转换,不够灵活且有一定的性能损耗。 而泛型接口则可以在接口定义时使用类型参数,通过类型参数来指定接口的具体类型。这样一来,在使用时就可以直接将对应类型的数据传入接口中,无需进行类型转换。 泛型接口的引入为Go语言提供了更加灵活和高效的编程方式。通过泛型接口,我们可以编写更加通用和复用的代码。它还能帮助我们更好地约束函数和数据类型之间的关系,提高代码的健壮性和可读性。 不过需要注意的是,泛型接口的引入也会带来一定的复杂性。在使用泛型接口时,我们需要仔细考虑类型参数的合理性和边界条件,并且需要充分测试以确保代码的正确性。 总之,引入泛型接口是Go语言进一步发展的一大步。它提供了更多的编程方式,并且可以在一定程度上简化代码和提高效率。希望未来随着泛型接口的进一步成熟和普及,我们可以看到更多高质量、灵活和通用的Go代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值