当前位置: 首页 > wzjs >正文

自己做的网站百度搜不到超级seo工具

自己做的网站百度搜不到,超级seo工具,企业管理软件属于系统软件吗,小草2022新地扯一二本期分享: 1. runtime.Caller(1)获取调用者信息 2. for循环 select{}语法 正文: runtime.Caller(1)获取调用者信息 在 Go 语言中,runtime.Caller(1) 是 runtime 包提供的一个函数,用于获取当前 goroutine 的调用堆栈中的特定…

本期分享

1. runtime.Caller(1)获取调用者信息

2. for循环 + select{}语法


正文

runtime.Caller(1)获取调用者信息

在 Go 语言中,runtime.Caller(1)runtime 包提供的一个函数,用于获取当前 goroutine 的调用堆栈中的特定调用者的信息。这里的 1 表示要跳过的调用帧数。具体来说,当你调用 runtime.Caller(1) 时,它会返回调用 runtime.Caller 的函数的调用者的信息。

这个函数的返回值:

  • 程序计数器(Program Counter, PC):一个指向当前执行指令的内存地址。
  • 文件名:调用发生时的源文件路径。
  • 行号:调用发生时的源代码行号。
  • 一个布尔值,表示是否成功获取到了调用信息。
使用示例

以下是一个简单的示例,展示了如何在 Go 程序中使用 runtime.Caller(1) 来获取并打印调用者的信息:

func getCallerInfo() (string, string, int) {pc, file, line, ok := runtime.Caller(1)if !ok {return "", "", 0}funcName := runtime.FuncForPC(pc).Name()return funcName, file, line
}func TestCallerInfo(t *testing.T) {funcName, file, line := getCallerInfo()fmt.Printf("func name: %s \n", funcName)fmt.Printf("call file: %s \n", file)fmt.Printf("code line: %d \n", line)
}

输出:

func name: code/code_28.TestCallerInfo 
call file: E:/xxx/code/code_28/caller_info_test.go 
code line: 19 
注意事项

1)获取调用堆栈信息有一定的性能开销,因此不建议在性能敏感的代码路径中频繁使用。

2)在生产环境中,调用堆栈信息通常用于日志记录,以便在出现问题时进行分析和调试。

3)runtime.Caller 和相关的函数是 Go 语言提供的底层运行时接口,它们允许开发者深入了解程序的执行过程,但也需要谨慎使用以避免引入不必要的复杂性或性能问题。

for循环 + select{}语法

在Go语言中,for循环 + select{}语法是一种用于处理多个通道(channel)的并发操作的语法结构。它允许你在一个循环中同时等待多个通道的操作,并且可以根据哪个通道准备好进行相应的处理。

使用场景

for循环 + select{}语法通常用于以下场景:

1)并发处理多个通道:当你需要同时处理多个通道的输入或输出时,可以使用 for select 来避免阻塞并高效地处理数据。

2)超时处理:通过在 select 语句中添加 time.After 或 time.Tick 通道,可以实现超时机制或定时任务。

3)资源管理:在处理多个资源时,可以使用 for select 来确保资源的正确释放和清理。

4)事件驱动编程:在事件驱动的程序中,for select 可以用于监听多个事件源,并根据事件的发生进行相应的处理。

示例

以下是一个简单的示例,展示了如何使用 for select 来处理多个通道

func TestForSelect(t *testing.T) {ch1 := make(chan int)ch2 := make(chan string)go func() {for i := 0; i < 5; i++ {ch1 <- itime.Sleep(time.Second)}close(ch1)}()go func() {for i := 0; i < 5; i++ {ch2 <- fmt.Sprintf("message %d", i)time.Sleep(2 * time.Second)}close(ch2)}()for {select {case num, ok := <-ch1:if !ok {ch1 = nil // 通道关闭后设置为 nil,避免重复关闭} else {fmt.Println("Received from ch1:", num)}case msg, ok := <-ch2:if !ok {ch2 = nil // 通道关闭后设置为 nil,避免重复关闭} else {fmt.Println("Received from ch2:", msg)}case <-time.After(3 * time.Second):fmt.Println("Timeout")default:fmt.Println("No data received")time.Sleep(time.Second)}// 当所有通道都关闭时退出循环if ch1 == nil && ch2 == nil {break}}
}

在这个示例中,我们创建了两个通道 ch1 和 ch2,并分别在两个 goroutine 中向它们发送数据。在主 goroutine 中,我们使用 for select 来同时监听这两个通道,并根据哪个通道准备好进行相应的处理。当所有通道都关闭时,循环退出。

注意事项

1)通道关闭:在处理通道时,需要注意通道的关闭状态,避免在通道关闭后继续读取或写入数据。

2)默认操作:default 分支在没有通道准备好时会被执行,可以用于避免阻塞。

3)超时处理:通过 time.After 或 time.Tick 通道可以实现超时机制,但需要注意避免资源泄漏。

通过合理使用 for select,你可以编写出高效、并发的Go程序。

本节完~

http://www.dtcms.com/wzjs/259197.html

相关文章:

  • 动态网站设计与制作seo长尾关键词排名
  • 做网站的需求分析十大营销模式
  • 网站只做优化seo图片优化的方法
  • 吉野家网站谁做的免费隐私网站推广
  • 怎么给公司做微网站竞价广告推广
  • 武汉专业建网站百度账号查询
  • 网站推广工做计划范本万网官网
  • 建立免费个人网站如何网络营销
  • 营销手机网站制作黄金网站app大全
  • 网站建设电商考试深圳网站设计专家乐云seo
  • 小公司怎样自己建网站德阳seo优化
  • 徐州网站开发设计公司电话推广平台排行榜有哪些
  • b2b网站有哪些模块seo关键词优化技巧
  • 苏州网站优化哪家好seo综合查询平台官网
  • 海淀团队组建网站深圳百度国际大厦
  • 杭州网站建设caiyiduosemi final
  • 顺德网站建设公司价位网络营销公司招聘
  • 大气学校网站模板优质的seo网站排名优化软件
  • 用DW 做响应式网站网络优化工程师骗局
  • 响应式网站对seo中国新闻今日头条
  • 网站设计要多久seo的培训课程
  • 网站设计的基本方法创建网站步骤
  • 外贸主动营销网站建设爱站网关键词查询工具
  • 热门网络游戏深圳债务优化公司
  • 电商网站 外包做营销怎样才能吸引客户
  • 网站上线之前怎么做推广百度上如何做优化网站
  • 网站建设第一品牌 网站设计关键词搜索优化
  • 阿里云做网站号码怎么快速推广自己的产品
  • 武汉疫情网易北京做网络优化的公司
  • 郑州网络营销公司哪家好济南做seo排名