ChatGPT 和文心一言哪个更好用?
强烈推荐
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站:人工智能
前言
上一篇,我们介绍了plugin、reflect、regexp三个库,这篇我们继续介绍剩下的库
几种库
runtime库 ( 运行时接口)
在 Go 语言的标准库中,runtime
包提供了与 Go 运行时系统交互的功能。
这个包包括了一些控制和查询运行时状态的函数,如协程控制、垃圾回收、程序退出等。
常用的函数:
-
Gosched
函数: 让出处理器给其他 goroutine 执行,以便调度器能够有效地分配时间给不同的 goroutine。 -
Go
函数: 用于启动一个新的 goroutine。 -
NumCPU
函数: 返回机器上的逻辑 CPU 核心数。 -
NumGoroutine
函数: 返回当前程序中活跃的 goroutine 数量。 -
GOMAXPROCS
函数: 用于设置或查询可同时执行的最大 CPU 核心数。 -
MemStats
结构和ReadMemStats
函数: 提供了对内存使用情况的统计信息。
示例
package main
import (
"fmt"
"runtime"
"sync"
)
func main() {
// 设置最大同时执行的 CPU 核心数
runtime.GOMAXPROCS(2)
// 获取机器上的逻辑 CPU 核心数
numCPU := runtime.NumCPU()
fmt.Println("Number of CPUs:", numCPU)
// 启动多个 goroutine
var wg sync.WaitGroup
for i := 0; i < 5; i++ {
wg.Add(1)
go func(index int) {
defer wg.Done()
fmt.Printf("Goroutine %d is running on CPU %d\n", index, runtime.NumCPU())
}(i)
}
wg.Wait()
// 获取当前程序中活跃的 goroutine 数量
numGoroutines := runtime.NumGoroutine()
fmt.Println("Number of Goroutines:", numGoroutines)
// 让出处理器给其他 goroutine 执行
runtime.Gosched()
// 输出内存统计信息
var memStats runtime.MemStats
runtime.ReadMemStats(&memStats)
fmt.Printf("Allocated memory: %d bytes\n", memStats.Alloc)
fmt.Printf("Total memory allocated: %d bytes\n", memStats.TotalAlloc)
fmt.Printf("Heap memory allocated: %d bytes\n", memStats.HeapAlloc)
}
在这个示例中,使用了 runtime.GOMAXPROCS
设置最大同时执行的 CPU 核心数,使用 runtime.NumCPU
获取机器上的逻辑 CPU 核心数,使用 runtime.NumGoroutine
获取当前程序中活跃的 goroutine 数量。
还启动了多个 goroutine 并使用 runtime.Gosched
让出处理器给其他 goroutine 执行。最后,使用 runtime.ReadMemStats
输出内存统计信息。
sort库(排序接口)
在 Go 语言的标准库中,sort
包提供了对切片和用户定义的集合进行排序的功能。
它支持排序各种类型的数据,包括内置的基本数据类型以及用户定义的类型。
主要的函数和接口:
-
sort.Interface
接口: 用户定义的类型需要实现这个接口的三个方法(Len
、Less
、Swap
)来支持排序。这样的类型可以被sort
包的函数直接使用。 -
sort.Sort
函数: 对实现了sort.Interface
接口的类型进行原地排序。 -
sort.Slice
函数: 对切片进行排序,可以接受切片、比较函数和附加参数。 -
sort.Search
函数: 在有序切片中查找一个元素,并返回它的索引。如果找不到,返回应该插入的位置。
示例
package main
import (
"fmt"
"sort"
)
// 定义一个结构体类型
type Person struct {
Name string
Age int
}
// 定义一个实现 sort.Interface 接口的切片类型
type People []Person
func (p People) Len() int { return len(p) }
func (p People) Less(i, j int) bool { return p[i].Age < p[j].Age }
func (p People) Swap(i, j int) { p[i], p[j] = p[j], p[i] }
func main() {
// 基本数据类型的切片排序
intSlice := []int{5, 2, 7, 1, 8, 3}
sort.Ints(intSlice)
fmt.Println("Sorted Ints:", intSlice)
// 自定义类型的切片排序
people := People{
{"Alice", 25},
{"Bob", 30},
{"Charlie", 22},
}
sort.Sort(people)
fmt.Println("Sorted People:", people)
// 使用 sort.Slice 对切片进行排序
strSlice := []string{"banana", "apple", "orange", "grape"}
sort.Slice(strSlice, func(i, j int) bool {
return len(strSlice[i]) < len(strSlice[j])
})
fmt.Println("Sorted Strings by Length:", strSlice)
// 使用 sort.Search 在有序切片中查找元素
searchSlice := []int{1, 2, 3, 4, 5, 6, 7, 8, 9}
index := sort.Search(len(searchSlice), func(i int) bool {
return searchSlice[i] >= 6
})
fmt.Println("Index of 6 in Sorted Slice:", index)
}
在这个示例中,使用了 sort.Ints
和 sort.Sort
对切片进行排序。
同时,定义了一个 Person
结构体和一个实现了 sort.Interface
接口的 People
类型,然后使用 sort.Sort
对自定义类型的切片进行排序。
最后,使用 sort.Slice
对字符串切片进行排序,并使用 sort.Search
在有序切片中查找元素。
这些函数和接口提供了灵活而强大的排序功能,适用于各种排序需求。
strings库(字符串转换、解析及实用函数)
在 Go 语言的标准库中,strings
包提供了对字符串进行操作的各种函数。
这些函数包括字符串的拼接、切割、替换、搜索等,提供了丰富的字符串处理功能。
常用的函数:
-
Contains
函数: 判断字符串是否包含子串。 -
Count
函数: 统计子串在字符串中出现的次数。 -
HasPrefix
和HasSuffix
函数: 判断字符串是否以指定的前缀或后缀开始或结束。 -
Index
和LastIndex
函数: 返回子串在字符串中第一次和最后一次出现的位置。 -
Join
函数: 将字符串切片连接成一个字符串,中间用指定的分隔符分隔。 -
Replace
函数: 替换字符串中的指定子串。 -
Split
函数: 将字符串切割成字符串切片,根据指定的分隔符。 -
ToLower
和ToUpper
函数: 将字符串转换为小写或大写。
示例
package main
import (
"fmt"
"strings"
)
func main() {
// Contains函数:判断字符串是否包含子串
fmt.Println(strings.Contains("Hello, Gophers!", "Go")) // true
// Count函数:统计子串在字符串中出现的次数
fmt.Println(strings.Count("banana", "a")) // 3
// HasPrefix和HasSuffix函数:判断字符串是否以指定的前缀或后缀开始或结束
fmt.Println(strings.HasPrefix("Gopher", "Go")) // true
fmt.Println(strings.HasSuffix("Gopher", "per")) // true
// Index和LastIndex函数:返回子串在字符串中第一次和最后一次出现的位置
fmt.Println(strings.Index("Hello, Gophers!", "Gophers")) // 7
fmt.Println(strings.LastIndex("Hello, Gophers!", "o")) // 10
// Join函数:将字符串切片连接成一个字符串,中间用指定的分隔符分隔
strSlice := []string{"apple", "banana", "orange"}
joinedString := strings.Join(strSlice, ", ")
fmt.Println(joinedString) // apple, banana, orange
// Replace函数:替换字符串中的指定子串
replacedString := strings.Replace("Hello, Gophers!", "Gophers", "World", -1)
fmt.Println(replacedString) // Hello, World!
// Split函数:将字符串切割成字符串切片,根据指定的分隔符
splitString := strings.Split("apple,banana,orange", ",")
fmt.Println(splitString) // [apple banana orange]
// ToLower和ToUpper函数:将字符串转换为小写或大写
lowerString := strings.ToLower("golang")
upperString := strings.ToUpper("GoLang")
fmt.Println(lowerString, upperString) // golang GOLANG
}
这些函数提供了丰富的字符串处理功能,可以满足各种字符串操作的需求。
time库(时间接口)
在 Go 语言的标准库中,time
包提供了对时间的处理和操作功能。
time
包主要包含了表示时间的结构体、时间的格式化和解析、定时器等相关的功能。
常用的函数:
-
Time
类型: 表示一个具体的时间点。Time
类型的值可以通过time.Now()
获取当前时间,也可以通过time.Parse
解析字符串得到。 -
Duration
类型: 表示时间间隔,用于表示两个Time
值之间的差异。 -
time.Now
函数: 获取当前时间。 -
time.After
和time.Sleep
函数: 用于等待一段时间。 -
time.Parse
和time.Format
函数: 用于时间格式的解析和格式化。 -
time.Timer
和time.Ticker
类型: 分别表示定时器和周期性的定时器。
示例
package main
import (
"fmt"
"time"
)
func main() {
// 获取当前时间
now := time.Now()
fmt.Println("Current Time:", now)
// 格式化时间
fmt.Println("Formatted Time:", now.Format("2006-01-02 15:04:05"))
// 解析时间字符串
parsedTime, err := time.Parse("2006-01-02", "2023-01-01")
if err != nil {
fmt.Println("Error parsing time:", err)
return
}
fmt.Println("Parsed Time:", parsedTime)
// 时间间隔(Duration)
duration := 3 * time.Second
fmt.Println("Duration:", duration)
// 等待一段时间
time.Sleep(2 * time.Second)
fmt.Println("After Sleep")
// 定时器
timer := time.NewTimer(1 * time.Second)
<-timer.C
fmt.Println("Timer expired")
// 周期性定时器
ticker := time.NewTicker(500 * time.Millisecond)
for i := 0; i < 5; i++ {
<-ticker.C
fmt.Println("Ticker Tick", i+1)
}
ticker.Stop()
fmt.Println("Ticker stopped")
}
在这个示例中,使用 time.Now
获取当前时间,使用 Format
格式化时间,使用 time.Parse
解析时间字符串,使用 time.Sleep
等待一段时间,使用 time.NewTimer
创建定时器,使用 time.NewTicker
创建周期性的定时器等。
text库(文本模板及 Token 词法器)
在 Go 语言的标准库中,“text” 包并不存在。
只有一些与文本处理相关的包,比如 text/template
或 text/scanner
。
1.text/template
包:
提供了一种简单的模板引擎,用于生成文本输出。它允许在模板中嵌入变量和控制结构,然后通过传入数据来生成最终的文本输出。
示例
package main
import (
"os"
"text/template"
)
func main() {
// 定义模板
tpl := "Hello, {{.Name}}! Today is {{.Day}}."
// 创建模板对象
t := template.Must(template.New("greeting").Parse(tpl))
// 准备数据
data := map[string]interface{}{
"Name": "Gopher",
"Day": "Wednesday",
}
// 渲染模板
t.Execute(os.Stdout, data)
}
2.text/scanner
包:
提供了一个用于扫描文本的基本扫描器。这个包可用于将文本分割成令牌(Token)并对其进行处理。
示例
package main
import (
"fmt"
"strings"
"text/scanner"
)
func main() {
// 创建扫描器
var s scanner.Scanner
s.Init(strings.NewReader("Hello, World!"))
// 扫描并打印令牌
for tok := s.Scan(); tok != scanner.EOF; tok = s.Scan() {
fmt.Printf("Token: %s\n", s.TokenText())
}
}
总结
这里我们介绍了5个库runtime、sort、strings、time、text ,至此,所有的标准库都已经介绍完了
专栏集锦
大佬们可以收藏以备不时之需:
Spring Boot 专栏:http://t.csdnimg.cn/peKde
ChatGPT 专栏:http://t.csdnimg.cn/cU0na
Java 专栏:http://t.csdnimg.cn/YUz5e
Go 专栏:http://t.csdnimg.cn/Jfryo
Netty 专栏:http://t.csdnimg.cn/0Mp1H
Redis 专栏:http://t.csdnimg.cn/JuTue
Mysql 专栏:http://t.csdnimg.cn/p1zU9
架构之路 专栏:http://t.csdnimg.cn/bXAPS
强烈推荐
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站:人工智能
写在最后
感谢您的支持和鼓励! 😊🙏
如果大家对相关文章感兴趣,可以关注公众号"架构殿堂",会持续更新AIGC,java基础面试题, netty, spring boot, spring cloud, Go,python等系列文章,一系列干货随时送达!